@font-face{font-family:Outfit;font-weight:400;font-style:normal;font-display:swap;src:url(/assets/outfit_regular-3b64ac4f.ttf) format("truetype")}@font-face{font-family:Outfit;font-weight:500;font-style:normal;font-display:swap;src:url(/assets/outfit_medium-dc8d9212.ttf) format("truetype")}@font-face{font-family:Outfit;font-weight:600;font-style:normal;font-display:swap;src:url(/assets/outfit_semibold-bf2e1d2a.ttf) format("truetype")}@font-face{font-family:Outfit;font-weight:700;font-style:normal;font-display:swap;src:url(/assets/outfit_bold-f620b695.ttf) format("truetype")}:root{--brand-50: #F2F4FA;--brand-100: #E4E8F5;--brand-200: #C6CEE9;--brand-300: #A1ADD9;--brand-400: #7A88C7;--brand-500: #5E6FB1;--brand-600: #495D92;--brand-700: #3C4D78;--brand-800: #2F3C5E;--brand-900: #1F293F;--color-primary: var(--brand-600);--color-primary-light: var(--brand-500);--color-primary-dark: var(--brand-700);--color-accent: #f59e0b;--color-bg-light: var(--brand-50);--color-card-bg: #ffffff;--color-text-primary: #1e293b;--color-text-secondary: #64748b;--color-border: #cbd5e1;--color-success: #0ca874;--color-success-light: #ecfdf5;--color-error: #ef4444;--color-error-light: #fef2f2;--color-warning: #f59e0b;--color-warning-light: #fffbeb;--shadow-sm: 0 1px 3px rgba(0, 0, 0, .12), 0 1px 2px rgba(0, 0, 0, .24);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1), 0 2px 4px -1px rgba(0, 0, 0, .06);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1), 0 4px 6px -2px rgba(0, 0, 0, .05);--border-radius: 12px;--transition-fast: .2s ease;--transition-normal: .3s ease}*{box-sizing:border-box;margin:0;padding:0}body{font-family:Outfit,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:#121212;color:var(--color-text-primary);margin:0;padding:0;min-height:100vh;min-height:100dvh;min-height:calc(var(--vh, 1vh) * 100);overflow:hidden}#root{width:100%;min-height:100vh;min-height:100dvh;min-height:calc(var(--vh, 1vh) * 100);display:flex;justify-content:center;align-items:center}.mobile-shell{width:100%;min-width:min(390px,100%);max-width:440px;height:100vh;height:100dvh;height:calc(var(--vh, 1vh) * 100);max-height:900px;background-color:var(--color-bg-light);box-shadow:0 19px 38px #0000004d,0 15px 12px #00000038;border-radius:0;position:relative;display:flex;flex-direction:column;overflow:hidden}@media (min-width: 450px){.mobile-shell{border-radius:20px;height:90vh;height:90dvh}}.loading-screen{display:flex;flex-direction:column;justify-content:center;align-items:center;height:100%;background-color:var(--color-bg-light)}.spinner{width:40px;height:40px;border:4px solid var(--color-primary-light);border-top:4px solid var(--color-primary);border-radius:50%;animation:spin 1s linear infinite;margin-bottom:12px}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.animate-fade-in{animation:fadeIn var(--transition-normal)}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.animate-shake{animation:shake .4s ease-in-out}@keyframes shake{0%,to{transform:translate(0)}25%{transform:translate(-6px)}75%{transform:translate(6px)}}.wl-root{height:100%;display:flex;flex-direction:column;position:relative;background-color:var(--color-bg-light);overflow:hidden}.wl-decor-blob{position:absolute;top:88px;right:0;width:140px;height:140px;pointer-events:none;z-index:0}.wl-decor-top-center{position:absolute;top:-10px;left:55%;width:75px;height:75px;pointer-events:none;z-index:0}.wl-decor-top-center svg{transform:rotate(90deg)}.wl-decor-left-mid{position:absolute;top:295px;left:-20px;width:100px;height:100px;pointer-events:none;z-index:0}.wl-decor-left-mid svg{transform:rotate(180deg)}.wl-decor-bottom-right{position:absolute;bottom:-10%;right:-10%;width:60%;aspect-ratio:1 / 1;pointer-events:none;z-index:0}.wl-decor-bottom-right svg{transform:rotate(90deg)}.wl-decor-below-form{width:45px;height:45px;margin-top:15px;margin-left:15px;align-self:flex-start;pointer-events:none;z-index:0}.wl-decor-below-form svg{transform:rotate(270deg)}.wl-decor-circle{position:absolute;width:10px;height:10px;border-radius:50%;background:transparent;border:1.4px solid rgba(43,127,188,.35);pointer-events:none;z-index:0}.wl-decor-circle--left{left:76px;top:420px}.wl-decor-circle--right{right:54px;top:470px}.wl-scroll{flex:1;overflow-y:scroll;overflow-x:hidden;scrollbar-width:none;padding:20px 24px 100px;position:relative;z-index:1;display:flex;flex-direction:column}.wl-scroll::-webkit-scrollbar{display:none}.wl-brand-row{display:flex;align-items:center;justify-content:space-between}.wl-brand-logo{height:32px;width:auto;object-fit:contain}.wl-brand-kerja{font-family:Outfit,sans-serif;font-weight:600;font-size:22px;color:var(--color-primary);letter-spacing:.2px}.wl-brand-row--tenant{justify-content:flex-start;gap:12px}.wl-brand-tenant-name{font-family:Outfit,sans-serif;font-weight:600;font-size:18px;color:var(--color-primary-dark);letter-spacing:.2px}.wl-welcome-prefix{display:block;margin-top:36px;font-family:Outfit,sans-serif;font-weight:400;font-size:16px;color:var(--color-primary-dark)}.wl-welcome-name{display:block;font-family:Outfit,sans-serif;font-weight:500;font-size:32px;line-height:1.1;color:var(--color-primary-dark);padding-top:5px;padding-bottom:10px}.wl-welcome-subtitle{display:block;margin-top:6px;font-family:Outfit,sans-serif;font-weight:400;font-size:14px;line-height:1.45;color:var(--color-text-secondary)}.wl-hero-wrap{width:160px;height:160px;align-self:center;margin-top:24px;margin-bottom:18px;position:relative;flex-shrink:0}.wl-hero-card{width:130px;height:130px;position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);border-radius:28px;background:linear-gradient(315deg,var(--brand-50),var(--brand-100));display:flex;align-items:center;justify-content:center;overflow:hidden}.wl-hero-worker-icon{width:75%;height:75%}.wl-hero-worker-fallback{width:75%;height:75%;background-color:var(--color-primary-dark);-webkit-mask-repeat:no-repeat;mask-repeat:no-repeat;-webkit-mask-position:center;mask-position:center;-webkit-mask-size:contain;mask-size:contain;flex-shrink:0}.wl-hero-avatar-photo{width:100%;height:100%;object-fit:cover;border-radius:28px}.wl-hero-badge{position:absolute;top:26px;right:18px;line-height:0;filter:drop-shadow(0 1px 2px rgba(0,0,0,.18))}.wl-error-banner{background-color:var(--color-error-light);border:1px solid var(--color-error);border-radius:8px;padding:12px;margin-bottom:12px;font-family:Outfit,sans-serif;font-weight:400;font-size:13px;color:#991b1b;text-align:center}.wl-progress{display:flex;justify-content:center;margin:22px 0}.wl-spinner{width:28px;height:28px;border:3px solid rgba(43,127,188,.25);border-top-color:var(--color-primary);border-radius:50%;animation:spin .9s linear infinite}.wl-form-card{width:100%;box-sizing:border-box;align-self:stretch;background-color:#fff;border-radius:18px;border:1px solid rgba(203,213,225,.6);padding:20px;display:flex;flex-direction:column;gap:0}.wl-form-card--pin-update{margin-top:14px}.wl-step{display:flex;flex-direction:column}.wl-field-label{display:flex;align-items:center;gap:8px;font-family:Outfit,sans-serif;font-weight:600;font-size:16px;color:var(--color-primary-dark);margin-bottom:0}.wl-edit-text{width:100%;height:52px;margin-top:10px;margin-bottom:14px;border:1px solid var(--color-border);border-radius:8px;background-color:#fff;font-family:Outfit,sans-serif;font-weight:400;font-size:16px;color:var(--color-text-primary);text-align:center;padding:0 16px;outline:none;transition:border-color .2s,box-shadow .2s;-webkit-appearance:none}.wl-edit-text::placeholder{color:#2b7fbc59}.wl-edit-text:focus{border-color:var(--color-primary);background-color:#eff8ff;box-shadow:0 0 0 2px #2b7fbc1f}.wl-security-row{display:flex;align-items:flex-start;gap:8px;font-family:Outfit,sans-serif;font-weight:400;font-size:14px;color:var(--color-text-secondary);line-height:1.4;margin-bottom:0}.wl-btn-primary{width:100%;height:56px;margin-top:18px;border:none;border-radius:14px;background:linear-gradient(90deg,var(--color-primary-light),var(--color-primary));color:#fff;font-family:Outfit,sans-serif;font-weight:600;font-size:16px;cursor:pointer;display:flex;align-items:center;justify-content:center;position:relative;box-shadow:0 4px 14px #2b7fbc47;transition:transform .15s,box-shadow .15s;-webkit-appearance:none;text-transform:none}.wl-btn-primary--solid{background:var(--color-primary)}.wl-btn-icon-right{position:absolute;right:20px;top:50%;transform:translateY(-50%);display:flex;align-items:center;justify-content:center}.wl-btn-primary:active{transform:scale(.98);box-shadow:0 2px 6px #2b7fbc2e}.wl-btn-primary:disabled{background:#cbd5e1;box-shadow:none;cursor:not-allowed;color:#94a3b8}.wl-btn-install{width:100%;min-height:48px;margin-top:12px;border:1px solid rgba(9,126,192,.22);border-radius:14px;background:rgba(255,255,255,.92);color:var(--color-primary);font-family:Outfit,sans-serif;font-weight:600;font-size:15px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:8px;box-shadow:0 10px 24px #0f172a0f;transition:transform .15s ease,box-shadow .15s ease,background-color .15s ease;-webkit-appearance:none}.wl-btn-install:active{transform:scale(.985);background:rgba(239,248,255,.98);box-shadow:0 6px 14px #0f172a14}.wl-pin-heading{font-family:Outfit,sans-serif;font-weight:600;font-size:18px;color:var(--color-primary);margin-bottom:0}.wl-pin-phone-row{display:flex;align-items:center;gap:0;margin-top:8px;margin-bottom:20px}.wl-pin-phone-display{display:flex;align-items:center;gap:6px;font-family:Outfit,sans-serif;font-weight:400;font-size:16px;color:var(--color-text-secondary)}.wl-btn-edit-mobile{display:flex;align-items:center;gap:4px;margin-left:16px;background:none;border:none;font-family:Outfit,sans-serif;font-weight:600;font-size:16px;color:var(--color-primary);cursor:pointer;padding:4px 6px;border-radius:6px;-webkit-appearance:none}.wl-btn-edit-mobile:active{background-color:var(--color-bg-light)}.wl-pin-row{display:flex;align-items:center;justify-content:center;gap:8px;height:50px;margin-bottom:18px;position:relative;cursor:pointer}.wl-hidden-input{position:absolute;top:0;right:0;bottom:0;left:0;opacity:0;width:100%;height:100%;z-index:10;cursor:pointer;border:none;background:transparent}.wl-pin-box{width:40px;height:45px;border-radius:8px;border:1px solid var(--color-text-secondary);background-color:var(--color-bg-light);display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:700;font-size:24px;color:var(--color-text-primary);transition:border-color .15s,box-shadow .15s,background-color .15s;flex-shrink:0}.wl-pin-box.active{border-color:var(--color-primary);background-color:var(--color-bg-light);box-shadow:0 0 0 1.5px var(--color-primary-light)}.wl-update-title{display:block;text-align:center;font-family:Outfit,sans-serif;font-weight:700;font-size:18px;color:var(--color-text-primary);margin-bottom:8px}.wl-update-subtitle{display:block;text-align:center;font-family:Outfit,sans-serif;font-weight:400;font-size:13px;color:var(--color-text-secondary);line-height:1.45;margin-bottom:20px}.wl-btn-back-link{align-self:center;background:none;border:none;font-family:Outfit,sans-serif;font-weight:600;font-size:13px;color:var(--color-primary);cursor:pointer;padding:8px;margin-top:0;-webkit-appearance:none}.wl-footer{position:absolute;bottom:20px;left:0;right:0;display:flex;align-items:center;justify-content:center;gap:0;z-index:2;pointer-events:none}.wl-footer-text{font-family:Outfit,sans-serif;font-weight:400;font-size:11px;color:var(--color-primary-dark);margin-right:4px}.wl-footer-logo{width:16px;height:16px;object-fit:contain;margin-right:4px}.wl-footer-brand{font-family:Outfit,sans-serif;font-weight:700;font-size:11px;color:var(--color-primary-dark)}.wl-footer-sep{font-size:11px;color:var(--color-text-secondary);margin:0 10px}.login-container,.login-card-wrapper,.brand-header,.worker-hero-card,.login-form,.subtitle,.input-group,.phone-input-wrapper,.phone-prefix,.security-note,.btn-primary,.btn-back,.pin-display-row,.pin-phone-display,.pin-phone-edit,.pin-inputs-wrapper,.pin-box,.warning-banner,.error-banner{display:none}.login-decor-blob{position:absolute;top:-40px;right:-40px;width:140px;height:140px;border-radius:50%;background:radial-gradient(circle,rgba(43,154,223,.15) 0%,rgba(43,127,188,0) 70%);pointer-events:none;z-index:1}.login-decor-circle{position:absolute;top:120px;left:30px;width:16px;height:16px;border-radius:50%;background-color:#0ca8741a;pointer-events:none;z-index:1}.login-decor-wave{position:absolute;bottom:0;left:0;width:100%;height:88px;background:linear-gradient(180deg,rgba(237,247,255,0) 0%,rgba(43,154,223,.06) 100%);pointer-events:none;z-index:1}.login-card-wrapper{z-index:2;margin:16px 24px 24px;background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:24px;padding:24px;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.7)}.brand-header{text-align:center;margin-top:32px;margin-bottom:20px;z-index:2}.brand-logo-img{height:36px;margin-bottom:8px}.brand-title{font-size:20px;font-weight:800;color:var(--color-primary-dark);letter-spacing:.5px}.worker-hero-card{width:120px;height:120px;background:white;border-radius:20px;box-shadow:var(--shadow-md);margin:0 auto 24px;position:relative;display:flex;align-items:center;justify-content:center;border:1px solid rgba(255,255,255,.8);z-index:2}.worker-hero-avatar{width:80px;height:80px;object-fit:cover;border-radius:12px}.worker-hero-avatar-placeholder{width:80px;height:80px;border-radius:12px;background-color:var(--color-bg-light);display:flex;align-items:center;justify-content:center;color:var(--color-primary)}.worker-hero-avatar-placeholder svg{width:48px;height:48px;opacity:.8}.worker-hero-badge{position:absolute;top:-8px;right:-8px;width:28px;height:28px;background-color:var(--color-success);border-radius:50%;border:3px solid white;display:flex;align-items:center;justify-content:center;color:#fff;font-size:12px;font-weight:700;box-shadow:var(--shadow-sm)}.login-form h2{font-size:18px;font-weight:700;color:var(--color-text-primary);margin-bottom:6px}.subtitle{font-size:13px;color:var(--color-text-secondary);margin-bottom:20px;line-height:1.4}.input-group{margin-bottom:20px}.input-group label{display:flex;align-items:center;gap:6px;font-size:12px;font-weight:600;color:var(--color-text-secondary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.phone-input-wrapper{display:flex;align-items:center;border:1px solid var(--color-border);border-radius:12px;background-color:#fff;overflow:hidden;height:52px;transition:var(--transition-fast)}.phone-input-wrapper:focus-within{border-color:var(--color-primary);box-shadow:0 0 0 3px #2b7fbc26}.phone-prefix{padding:0 16px;background-color:#f1f5f9;font-weight:700;color:var(--color-text-primary);border-right:1px solid var(--color-border);height:100%;display:flex;align-items:center}.phone-input-wrapper input{border:none;padding:0 16px;width:100%;font-size:16px;outline:none;font-weight:600;color:var(--color-text-primary)}.security-note{display:flex;align-items:center;gap:8px;font-size:11px;color:var(--color-text-secondary);margin-top:12px;margin-bottom:12px}.security-note svg{color:var(--color-success);flex-shrink:0}.btn-primary{width:100%;height:50px;background:linear-gradient(90deg,var(--color-primary-light),var(--color-primary));color:#fff;border:none;border-radius:14px;font-size:16px;font-weight:600;cursor:pointer;box-shadow:0 4px 12px #2b7fbc40;transition:var(--transition-fast);display:flex;align-items:center;justify-content:center;gap:8px}.btn-primary:active{transform:scale(.98);box-shadow:0 2px 6px #2b7fbc26}.btn-primary:disabled{background:#cbd5e1;box-shadow:none;cursor:not-allowed;color:#94a3b8}.btn-back{border:none;background:none;color:var(--color-primary);font-weight:600;font-size:14px;cursor:pointer;margin-bottom:16px;outline:none;display:flex;align-items:center;gap:6px}.pin-display-row{display:flex;align-items:center;gap:8px;margin-top:8px;margin-bottom:20px}.pin-phone-display{display:flex;align-items:center;gap:4px;font-size:14px;font-weight:500;color:var(--color-text-secondary)}.pin-phone-edit{background:none;border:none;color:var(--color-primary);font-weight:600;font-size:14px;cursor:pointer;padding:2px 6px;border-radius:4px;display:flex;align-items:center;gap:4px}.pin-phone-edit:active{background-color:var(--color-bg-light)}.pin-inputs-wrapper{display:flex;justify-content:center;gap:8px;margin:18px 0;position:relative}.pin-box{width:40px;height:45px;border:1px solid var(--color-text-secondary);border-radius:8px;text-align:center;font-size:24px;font-weight:700;background-color:var(--color-bg-light);display:flex;align-items:center;justify-content:center;color:var(--color-text-primary);transition:var(--transition-fast)}.pin-box.active{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-light);background-color:#fff}.warning-banner{background-color:var(--color-warning-light);border-left:4px solid var(--color-warning);padding:12px;border-radius:6px;margin-bottom:20px;font-size:13px;color:#7c2d12}.warning-banner strong{display:block;margin-bottom:2px}.section-label{font-size:12px;font-weight:600;color:var(--color-text-secondary);text-transform:uppercase}.error-banner{background-color:var(--color-error-light);border:1px solid var(--color-error);color:#991b1b;padding:10px 14px;border-radius:8px;margin-bottom:16px;font-size:13px;font-weight:500}.dashboard-container{display:flex;flex-direction:column;height:100%}.profile-header-card{background:var(--brand-700);padding:10px 15px 20px;color:#fff;box-shadow:var(--shadow-md);display:flex;justify-content:space-between;align-items:center;box-sizing:border-box}.header-left{display:flex;flex-direction:column;flex:1;min-width:0}.text-greeting{font-family:Outfit,sans-serif;font-weight:500;font-size:14px;color:#ffffffb3;letter-spacing:.02em}.text-name{font-family:Outfit,sans-serif;font-weight:700;font-size:20px;color:#fff;margin-top:2px;margin-right:16px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.layout-info{display:flex;align-items:center;margin-top:8px}.info-item{display:flex;align-items:center}.divider-line{width:1px;height:12px;background-color:#ffffff40;margin:0 10px}.text-role,.text-category{font-family:Outfit,sans-serif;font-size:13px;color:#fff}.card-status-badge{background-color:#0000001a;border-radius:12px;margin-top:12px;align-self:flex-start;display:inline-flex}.text-status-badge{font-family:Outfit,sans-serif;font-weight:700;font-size:11px;color:#fffc;padding:4px 10px;white-space:nowrap}.avatar-container{position:relative;width:72px;height:72px;flex-shrink:0}.image-wrapper{width:72px;height:72px;border-radius:36px;border:1px solid white;background-color:#fff3;overflow:hidden;display:flex;align-items:center;justify-content:center;box-sizing:border-box}.image-profile{width:100%;height:100%;object-fit:cover}.image-profile-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:700;font-size:24px;color:var(--brand-50)}.status-dot{position:absolute;width:14px;height:14px;border-radius:50%;bottom:4px;right:4px;border:2px solid var(--brand-700);z-index:4}.status-dot.active{background-color:#2e7d32}.status-dot.inactive{background-color:#757575}.tab-viewport{flex:1;overflow-y:auto;padding:0 0 80px}.footer-nav{position:absolute;bottom:0;left:0;width:100%;height:64px;padding:4px;background-color:var(--brand-50);border-top:1px solid var(--brand-500);box-sizing:border-box;display:flex;justify-content:space-between;align-items:center;z-index:10}.footer-nav button{background:none;border:none;display:flex;flex-direction:column;align-items:center;color:var(--color-text-secondary);font-size:12px;font-weight:600;line-height:1;cursor:pointer;flex:1;height:100%;padding:6px 0 4px;outline:none;justify-content:center;gap:4px;font-family:Outfit,sans-serif;transition:color .18s ease,opacity .18s ease,transform .18s ease}.footer-nav button .icon{font-size:24px;flex-shrink:0}.footer-nav button.active{color:var(--color-primary-dark)}.footer-nav button.active .icon{transform:none}.footer-nav button .label{white-space:nowrap}.footer-nav button:active{transform:scale(.95);opacity:.82}.hero-action-section{text-align:center;margin-bottom:24px}.hero-action-section .current-date{font-size:13px;color:var(--color-text-secondary);margin-bottom:16px;font-weight:700;align-self:center}.clock-in-card{background-color:#fff;border-radius:var(--border-radius);padding:24px;box-shadow:var(--shadow-sm);border:1px solid var(--color-border)}.clock-in-timer{margin-bottom:20px}.clock-in-timer .label{font-size:11px;font-weight:700;color:var(--color-text-secondary);display:block}.clock-in-timer .time{font-size:20px;font-weight:700;color:var(--color-text-primary)}.status-desc{font-size:13px;color:var(--color-text-secondary);margin-bottom:20px}.btn-action-clock{width:140px;height:140px;border-radius:50%;border:none;font-weight:700;font-size:16px;color:#fff;cursor:pointer;outline:none;box-shadow:0 8px 16px #00000026;transition:var(--transition-normal)}.btn-action-clock.check-in{background:linear-gradient(135deg,#4caf50,#2e7d32)}.btn-action-clock.check-out{background:linear-gradient(135deg,#f44336,#c62828)}.btn-action-clock:active{transform:scale(.96);box-shadow:0 4px 8px #00000026}.summary-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-top:16px}.summary-card{background-color:#fff;border-radius:12px;padding:16px;border:1px solid var(--color-border)}.summary-card h4{font-size:11px;color:var(--color-text-secondary);text-transform:uppercase;margin-bottom:4px}.summary-card p{font-size:15px;font-weight:700;color:var(--color-text-primary)}.pane-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.btn-secondary{padding:8px 16px;background-color:#fff;border:1px solid var(--color-primary);color:var(--color-primary-dark);border-radius:8px;font-size:13px;font-weight:700;cursor:pointer;transition:var(--transition-fast)}.btn-secondary:active{background-color:var(--color-primary-light)}.leave-balance-row{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;margin-bottom:24px}.balance-card{flex:0 0 120px;background-color:#fff;border-radius:12px;padding:12px;border:1px solid var(--color-border);display:flex;flex-direction:column}.balance-card .type-label{font-size:10px;color:var(--color-text-secondary);font-weight:700;text-transform:uppercase}.balance-card .hours{font-size:18px;font-weight:700;color:var(--color-primary-dark);margin:4px 0}.balance-card .year{font-size:9px;color:var(--color-text-secondary)}.transaction-history h4,.details-history h4{font-size:13px;text-transform:uppercase;color:var(--color-text-secondary);margin-bottom:12px}.tx-list,.detail-list{display:flex;flex-direction:column;gap:12px}.tx-item,.detail-item{background-color:#fff;border-radius:10px;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;border:1px solid var(--color-border)}.tx-meta .tx-type{font-weight:700;font-size:14px;display:block}.tx-meta .tx-dates{font-size:12px;color:var(--color-text-secondary)}.tx-status{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.status-pill{font-size:10px;font-weight:700;padding:4px 8px;border-radius:20px;text-transform:uppercase}.status-pill.approved{background-color:var(--color-success-light);color:var(--color-success)}.status-pill.pending{background-color:var(--color-warning-light);color:var(--color-warning)}.status-pill.rejected{background-color:var(--color-error-light);color:var(--color-error)}.tx-status .duration{font-size:12px;color:var(--color-text-secondary)}.history-header{display:flex;justify-content:space-between;align-items:center;padding:12px 20px 6px}.history-title{font-family:Outfit,sans-serif;font-size:12px;font-weight:700;color:#2b9adf;letter-spacing:.1em}.history-count{font-family:Outfit,sans-serif;font-size:12px;color:var(--color-text-secondary)}.history-list{display:flex;flex-direction:column;gap:16px;margin-top:16px;padding:0 16px}.history-card{background-color:#fff;border-radius:16px;border:1px solid var(--color-primary);overflow:hidden;padding:16px;cursor:pointer;transition:transform .2s cubic-bezier(.16,1,.3,1),box-shadow .2s cubic-bezier(.16,1,.3,1)}.history-card:hover{transform:translateY(-2px);box-shadow:0 6px 16px #495d9226}.history-card:active{transform:translateY(0)}.history-card-header-inner{display:flex;justify-content:space-between;align-items:center;width:100%}.status-badge-left{display:flex;align-items:center}.history-status-icon-box{width:36px;height:36px;border-radius:10px;background-color:#d1fae5;display:flex;align-items:center;justify-content:center;flex-shrink:0}.history-status-label{font-family:Outfit,sans-serif;font-size:13px;font-weight:700;color:#059669;margin-left:12px;letter-spacing:.05em}.history-duration{font-family:Outfit,sans-serif;font-size:12px;font-weight:700;color:#059669;margin-left:8px}.history-date{font-family:Outfit,sans-serif;font-size:12px;font-weight:700;color:#2b9adf}.history-divider{height:1px;background-color:var(--color-primary);opacity:.5;margin:12px 0}.history-card-body-inner{display:flex;align-items:center;justify-content:space-between;width:100%}.history-logs-container{display:flex;flex-direction:column;flex:1;min-width:0}.history-log-row-new{display:flex;align-items:flex-start;width:100%}.margin-top-12{margin-top:12px}.history-time-col{width:70px;flex-shrink:0;display:flex;flex-direction:column}.history-loc-col{flex:1;display:flex;flex-direction:column;padding-left:8px;min-width:0}.history-field-label{font-family:Outfit,sans-serif;font-size:11px;font-weight:700;color:#f59e0b;letter-spacing:.02em}.history-field-value{font-family:Outfit,sans-serif;color:var(--color-text-primary);margin-top:2px}.history-field-value.time{font-size:16px;font-weight:700}.history-field-value.loc{font-size:14px;font-weight:400;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.history-right-actions{display:flex;align-items:center;flex-shrink:0;margin-left:12px}.history-shift-name{font-family:Outfit,sans-serif;font-size:12px;font-weight:700;color:#f59e0b;margin-right:8px;text-align:right;max-width:100px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.history-chevron{color:var(--color-primary);flex-shrink:0}.history-list .empty-state-view{background-color:transparent;padding:60px 16px}.comp-summary-card{background:linear-gradient(135deg,#374151,#1f2937);border-radius:var(--border-radius);padding:20px;color:#fff;margin-bottom:24px}.comp-summary-card .label{font-size:11px;text-transform:uppercase;opacity:.8;display:block}.comp-summary-card .amount{font-size:24px;font-weight:800;display:block;margin:6px 0 16px;color:#fbbf24}.breakdown-simple{border-top:1px solid rgba(255,255,255,.1);padding-top:12px;display:flex;justify-content:space-between;font-size:13px}.month-picker{border:1px solid var(--color-border);border-radius:8px;padding:6px 12px;outline:none;font-weight:500}.profile-details-card{background-color:#fff;border-radius:var(--border-radius);border:1px solid var(--color-border);padding:16px;margin:16px 0 24px}.info-row{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid #f1f5f9;font-size:14px}.info-row:last-child{border-bottom:none}.info-row .label{color:var(--color-text-secondary)}.info-row .val{font-weight:700}.btn-danger{width:100%;padding:12px;background-color:var(--color-error-light);color:var(--color-error);border:1px solid var(--color-error);border-radius:var(--border-radius);font-weight:700;cursor:pointer}.btn-danger:active{background-color:#fee2e2}.modal-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-color:#00000080;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:100;display:flex;align-items:flex-end}.modal-content{background-color:#fff;width:100%;border-top-left-radius:20px;border-top-right-radius:20px;padding:24px;box-shadow:0 -10px 25px #0000001a;animation:slideUp .3s ease-out}.modal-content h3{margin-bottom:16px}.modal-backdrop-enter{opacity:1}.modal-backdrop-exit{opacity:0}.modal-content-enter{opacity:1;transform:translateY(0) scale(1)}.modal-content-exit{opacity:0;transform:translateY(8px) scale(.98)}.confirm-modal-shell{position:fixed;top:0;right:0;bottom:0;left:0;z-index:120;overflow-y:auto}.confirm-modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);transition:opacity .2s ease}.confirm-modal-positioner{min-height:100vh;min-height:100dvh;min-height:calc(var(--vh, 1vh) * 100);display:flex;align-items:center;justify-content:center;padding:16px}.confirm-modal-card{position:relative;width:100%;max-width:520px;background:#ffffff;border-radius:16px;overflow:hidden;box-shadow:0 24px 64px #0f172a3d;transition:opacity .2s ease,transform .2s ease}.confirm-modal-header{padding:14px 16px;display:flex;align-items:center;justify-content:space-between;color:#fff}.confirm-modal-header-left{display:flex;align-items:center;gap:8px;min-width:0}.confirm-modal-header-icon{display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.confirm-modal-title{margin:0;font-size:14px;font-weight:700;letter-spacing:.01em;font-family:Outfit,sans-serif;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.confirm-modal-close{border:none;background:transparent;color:inherit;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;opacity:1;transition:opacity .18s ease}.confirm-modal-close:disabled{cursor:default}.confirm-modal-close:not(:disabled):hover{opacity:.72}.confirm-modal-body{padding:24px}.confirm-modal-message-box{display:flex;gap:14px;padding:16px;border-left:4px solid;border-radius:0 10px 10px 0}.confirm-modal-message-icon{flex-shrink:0;display:inline-flex;align-items:flex-start;justify-content:center;margin-top:2px}.confirm-modal-message{color:#334155;font-size:14px;line-height:1.6;font-weight:600;font-family:Outfit,sans-serif}.confirm-modal-footer{padding:14px 24px;background:#f8fafc;display:flex;justify-content:flex-end;gap:12px;border-top:1px solid #e2e8f0}.confirm-modal-cancel,.confirm-modal-confirm{width:120px;min-height:42px;border-radius:12px;display:inline-flex;align-items:center;justify-content:center;gap:8px;font-size:14px;font-weight:600;font-family:Outfit,sans-serif;transition:transform .18s ease,opacity .18s ease,background-color .18s ease}.confirm-modal-cancel{border:1px solid #cbd5e1;background:#ffffff;color:#475569}.confirm-modal-confirm{border:none;color:#fff}.confirm-modal-cancel:active,.confirm-modal-confirm:active{transform:scale(.98)}.form-group{margin-bottom:16px}.form-group label{display:block;font-size:12px;font-weight:700;color:var(--color-text-secondary);margin-bottom:4px}.form-group select,.form-group input,.form-group textarea{width:100%;border:1px solid var(--color-border);border-radius:8px;padding:10px 12px;outline:none;font-size:14px}.form-group select:focus,.form-group input:focus,.form-group textarea:focus{border-color:var(--color-primary)}.modal-actions{display:flex;justify-content:flex-end;gap:12px;margin-top:20px}.btn-flat{background:none;border:none;color:var(--color-text-secondary);font-weight:700;cursor:pointer;padding:8px 16px}.attendance-capture-container{display:flex;flex-direction:column;height:100%;background-color:#000;position:relative}.capture-header{position:absolute;top:16px;left:16px;right:16px;height:56px;background-color:#000c;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-radius:12px;padding:8px 16px;display:flex;align-items:center;z-index:10;box-shadow:var(--shadow-lg);border:1px solid rgba(255,255,255,.1)}.btn-back-header{background:none;border:none;color:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;padding:8px;margin-right:8px;border-radius:50%;transition:background-color var(--transition-fast)}.btn-back-header:active{background-color:#ffffff26}.text-title-action{font-family:Outfit,sans-serif;font-weight:700;font-size:18px;margin-left:8px}.text-title-action.checkin{color:var(--color-success)}.text-title-action.checkout{color:var(--color-error)}.text-title-location{font-family:Outfit,sans-serif;font-weight:700;font-size:18px;color:var(--color-warning);margin-left:auto;text-align:right;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:50%}.capture-viewport-container{flex:1;position:relative;display:flex;align-items:center;justify-content:center;overflow:hidden;background-color:#000}.video-wrapper,.preview-wrapper{position:relative;max-width:100%;max-height:100%;display:flex;align-items:center;justify-content:center}.video-wrapper.is-processing{pointer-events:none}.video-wrapper.is-processing .video-stream{opacity:0}.video-stream{display:block;width:auto;height:auto;max-width:100%;max-height:100%;transform:scaleX(-1);transition:opacity .12s ease}.preview-image{display:block;width:auto;height:auto;max-width:100%;max-height:100%}.processing-frame-canvas{position:absolute;top:0;right:0;bottom:0;left:0;width:100%;height:100%;opacity:0;z-index:1;pointer-events:none;transition:opacity .12s ease}.processing-frame-canvas.visible{opacity:1}.camera-overlay-frame{position:absolute;top:40%;left:50%;transform:translate(-50%,-50%);width:280px;height:350px;pointer-events:none;box-shadow:0 0 0 9999px #00000073;z-index:2;color:#ffffffa6;transition:color var(--transition-fast)}.camera-overlay-frame.idle{color:#ffffffa6}.camera-overlay-frame.active{color:var(--color-success)}.camera-overlay-frame .corner{position:absolute;width:32px;height:32px;border:4px solid transparent;border-color:inherit;transition:border-color var(--transition-fast),filter var(--transition-fast)}.camera-overlay-frame.active .corner{filter:drop-shadow(0 0 6px rgba(12,168,116,.8))}.camera-overlay-frame .corner-tl{top:0;left:0;border-bottom:none;border-right:none}.camera-overlay-frame .corner-tr{top:0;right:0;border-bottom:none;border-left:none}.camera-overlay-frame .corner-bl{bottom:0;left:0;border-top:none;border-right:none}.camera-overlay-frame .corner-br{bottom:0;right:0;border-top:none;border-left:none}.camera-err-overlay{position:absolute;color:#fff;background-color:#f44336e6;padding:20px;border-radius:12px;text-align:center;margin:20px;z-index:3}.camera-processing-overlay{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;background:rgba(15,23,42,.42);color:#fff;z-index:4;font-family:Outfit,sans-serif;font-size:16px;font-weight:600;text-shadow:0 2px 8px rgba(0,0,0,.35)}.camera-processing-spinner,.btn-capture-spinner{border-radius:50%;border:4px solid rgba(255,255,255,.24);border-top-color:currentColor;animation:spin .9s linear infinite}.camera-processing-spinner{width:42px;height:42px;color:#fff}.error-banner-floating{position:absolute;top:84px;left:16px;right:16px;background-color:#ef4444e6;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);color:#fff;padding:12px 16px;border-radius:8px;display:flex;justify-content:space-between;align-items:center;z-index:12;box-shadow:var(--shadow-md);font-size:13px;font-weight:500;border-left:4px solid #b91c1c}.btn-close-error{background:none;border:none;color:#fff;font-size:20px;font-weight:700;cursor:pointer;padding:0 4px;line-height:1}.bottom-controls{position:absolute;bottom:0;left:0;right:0;padding:24px 24px 32px;background:linear-gradient(to top,rgba(0,0,0,1) 0%,rgba(0,0,0,.8) 60%,rgba(0,0,0,0) 100%);display:flex;flex-direction:column;align-items:center;justify-content:center;z-index:10}.text-instruction{font-family:Outfit,sans-serif;color:#fff;font-size:16px;font-weight:500;margin-bottom:24px;text-align:center;text-shadow:0 2px 4px rgba(0,0,0,.5)}.button-container{display:flex;justify-content:center;align-items:center;width:100%;min-height:80px}.capture-button-wrapper{position:relative;width:80px;height:80px;display:flex;align-items:center;justify-content:center}.btn-capture-circular{width:72px;height:72px;border-radius:50%;border:none;background-color:#fff;color:var(--brand-600);display:flex;align-items:center;justify-content:center;cursor:pointer;box-shadow:0 4px 12px #00000059;transition:transform var(--transition-fast),background-color var(--transition-fast);z-index:5}.btn-capture-circular.is-loading{color:var(--brand-600)}.btn-capture-circular:active{transform:scale(.92);background-color:#f1f5f9}.btn-capture-circular:disabled{background-color:#e2e8f0;color:#94a3b8;cursor:not-allowed;box-shadow:none}.btn-capture-spinner{width:28px;height:28px;border-width:3px;color:var(--brand-600)}.progress-indicator-circle{position:absolute;width:80px;height:80px;border-radius:50%;border:6px solid rgba(255,255,255,.15);border-top-color:var(--brand-500);animation:spin 1s linear infinite;pointer-events:none;z-index:4}@keyframes spin{to{transform:rotate(360deg)}}.submit-options{display:flex;gap:16px;width:100%;max-width:360px}.btn-retake{flex:1;padding:14px;background-color:#ffffff26;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);color:#fff;border:1px solid rgba(255,255,255,.2);font-weight:700;font-family:Outfit,sans-serif;border-radius:12px;cursor:pointer;font-size:14px;transition:background-color var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-retake:active{background-color:#ffffff40}.btn-submit{flex:1;padding:14px;background:linear-gradient(135deg,#0ca874,#059669);color:#fff;border:none;font-weight:700;font-family:Outfit,sans-serif;border-radius:12px;cursor:pointer;font-size:14px;box-shadow:0 4px 10px #0ca87440;transition:transform var(--transition-fast),box-shadow var(--transition-fast);display:inline-flex;align-items:center;justify-content:center;gap:8px}.btn-submit:active{transform:scale(.98);box-shadow:0 2px 5px #0ca87433}.card-location-status-pill{margin-top:16px;background-color:#000000d9;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border-radius:20px;padding:6px 16px;border:1px solid rgba(255,255,255,.1);box-shadow:var(--shadow-sm);max-width:90%}.location-pill-content{display:flex;align-items:center;gap:8px}.icon-location.warning{color:var(--color-warning);animation:pulse 1.5s ease-in-out infinite}.icon-location.success{color:var(--color-success)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.text-location-status{font-family:Outfit,sans-serif;font-size:12px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.location-error-wrapper{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.text-location-status.error{white-space:normal;overflow:visible;text-overflow:clip}.btn-retry-gps{background-color:var(--color-primary);color:#fff;border:none;border-radius:12px;padding:4px 10px;font-family:Outfit,sans-serif;font-size:11px;font-weight:600;cursor:pointer;white-space:nowrap;transition:background-color var(--transition-fast),transform .1s}.btn-retry-gps:hover{background-color:var(--color-primary-light)}.btn-retry-gps:active{transform:scale(.95)}.sticky-action-container{position:absolute;bottom:64px;left:0;right:0;z-index:99;display:flex;flex-direction:column;background:transparent;pointer-events:none;transition:transform .3s cubic-bezier(.16,1,.3,1),opacity .2s ease}.sticky-action-container.hidden{transform:translateY(120%);opacity:0;pointer-events:none}.sticky-action-gradient{width:100%;height:20px;background:linear-gradient(to top,var(--color-bg-light),rgba(237,247,255,0))}.sticky-action-wrapper{background-color:var(--color-bg-light);padding:8px 15px 10px;width:100%;display:flex;pointer-events:auto}.sticky-action-button{width:100%;height:48px;border-radius:28px;border:none;font-weight:700;font-size:15px;text-transform:uppercase;color:#fff;display:flex;align-items:center;justify-content:center;gap:12px;cursor:pointer;box-shadow:0 4px 10px #00000026;transition:transform .15s ease,background-color .2s ease}.sticky-action-button:active{transform:scale(.97);box-shadow:0 2px 5px #0000001a}.sticky-action-button.forest-green{background-color:#059669}.sticky-action-button.vermilion{background-color:#ef4444}.sticky-action-button.brand-blue{background-color:var(--color-primary)}.dashboard-section{background:white;border-radius:18px;padding:16px;margin-bottom:16px;border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.dashboard-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}.dashboard-section-title{font-size:12px;font-weight:700;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.8px}.weekly-row{display:flex;justify-content:space-between;gap:6px}.weekly-day-col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px}.weekly-day-label{font-size:10px;font-weight:700;color:var(--color-text-secondary)}.weekly-badge{width:100%;aspect-ratio:1;max-width:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:800;transition:var(--transition-fast)}.weekly-badge.zero{background-color:var(--color-bg-light);color:var(--color-text-secondary);border:1px solid var(--color-border)}.weekly-badge.partial{background-color:var(--color-accent);color:#fff}.weekly-badge.full{background-color:var(--color-success);color:#fff}.schedule-row{display:flex;gap:8px;overflow-x:auto;padding-bottom:6px;scrollbar-width:none}.schedule-row::-webkit-scrollbar{display:none}.schedule-day-card{flex:0 0 54px;display:flex;flex-direction:column;align-items:center;gap:8px;padding:8px 4px;background-color:#f8fafc;border-radius:12px;border:1px solid #f1f5f9}.schedule-day-card.today{border-color:var(--color-primary-light);background-color:var(--color-bg-light)}.schedule-day-name{font-size:10px;font-weight:700;color:var(--color-text-secondary)}.schedule-day-name.weekend{color:var(--color-error)}.schedule-day-date{font-size:12px;font-weight:800;color:var(--color-text-primary)}.schedule-day-date.weekend{color:var(--color-error)}.schedule-shift-badge{width:32px;height:32px;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:800;text-transform:uppercase}.weekly-section{margin-top:16px}.weekly-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.weekly-filter-btn{display:flex;align-items:center;cursor:pointer;padding:4px}.weekly-title{font-family:Outfit,sans-serif;font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--color-text-secondary)}.weekly-date-info{display:flex;align-items:center;font-family:Outfit,sans-serif;font-size:14px;font-weight:700}.current-day{color:var(--brand-800)}.current-date{color:var(--color-text-secondary);margin-left:8px}.weekly-card-container{background-color:#fff;border-radius:var(--border-radius);border:1px solid var(--color-border);padding:12px 6px}.weekly-status-row{display:flex;justify-content:space-between;align-items:center}.weekly-day-col{display:flex;flex-direction:column;align-items:center;flex:1}.weekly-day-label{font-family:Outfit,sans-serif;font-weight:700;font-size:11px;color:var(--brand-800);margin-bottom:6px;text-align:center}.weekly-day-label.weekend{color:#c2410c}.weekly-badge{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:700;font-size:12px;transition:background-color .2s,color .2s}.schedule-section{margin-top:24px}.schedule-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.schedule-title{font-family:Outfit,sans-serif;font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--color-text-secondary)}.btn-view-more{background:none;border:none;display:flex;align-items:center;color:var(--brand-600);font-family:Outfit,sans-serif;font-weight:700;font-size:11px;letter-spacing:.1em;cursor:default;padding:4px;outline:none;opacity:.8}.schedule-card-container{background-color:#fff;border-radius:var(--border-radius);border:1px solid var(--color-border);padding:12px 6px}.schedule-days-row{display:flex;justify-content:space-between;align-items:center}.schedule-day-column{display:flex;flex-direction:column;align-items:center;flex:1}.schedule-day-abbr{font-family:Outfit,sans-serif;font-weight:700;font-size:10px;letter-spacing:.06em;color:var(--brand-700);text-align:center}.schedule-day-abbr.non-working{color:var(--color-error)}.schedule-day-date{font-family:Outfit,sans-serif;font-size:9px;font-weight:500;letter-spacing:.04em;color:var(--brand-700);margin-top:1px;text-align:center}.schedule-day-date.non-working{color:var(--color-error)}.schedule-shift-code-badge{width:42px;height:42px;border-radius:10px;display:flex;align-items:center;justify-content:center;font-family:Outfit,sans-serif;font-weight:700;font-size:11px;margin-top:9px;box-sizing:border-box}.analytics-section{margin-top:20px}.analytics-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.analytics-filter-btn{display:flex;align-items:center;cursor:pointer;padding:4px}.analytics-title{font-family:Outfit,sans-serif;font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--color-text-secondary)}.analytics-subtitle{font-family:Outfit,sans-serif;font-size:12px;color:var(--color-text-secondary)}.analytics-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:8px}.analytics-card{height:96px;border-radius:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;padding:12px 8px;color:#fff;box-sizing:border-box;background-color:transparent;border:none}.analytics-card-value{font-family:Outfit,sans-serif;font-weight:700;font-size:16px;margin-top:8px}.analytics-card-label{font-family:Outfit,sans-serif;font-weight:500;font-size:10px;opacity:.8}.analytics-card.card-days-present{background-color:var(--color-primary)}.analytics-card.card-days-present .analytics-card-value{color:#dbeafe}.analytics-card.card-ontime{background-color:var(--color-success)}.analytics-card.card-ontime .analytics-card-value{color:#d1fae5}.analytics-card.card-avg-hours{background-color:var(--color-warning)}.analytics-card.card-avg-hours .analytics-card-value{color:#ffedd5}.analytics-card.card-outside{background-color:#8a6fa8}.analytics-card.card-outside .analytics-card-value{color:#f3e8ff}.activity-section{margin-top:24px}.activity-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.activity-title{font-family:Outfit,sans-serif;font-weight:700;font-size:12px;letter-spacing:.1em;color:var(--color-text-secondary)}.btn-view-history{background:none;border:none;display:flex;align-items:center;color:var(--color-primary);font-family:Outfit,sans-serif;font-weight:700;font-size:11px;letter-spacing:.1em;cursor:pointer;padding:4px;outline:none}.activity-card-container{background-color:#fff;border-radius:var(--border-radius);border:1px solid var(--color-border);overflow:hidden}.activity-item-row{display:flex;align-items:center;padding:12px 15px;background-color:var(--brand-50)}.activity-icon-card{width:48px;height:48px;border-radius:10px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon-card.checkin{background-color:#d1fae5}.activity-icon-card.checkout{background-color:var(--color-error-light)}.activity-details-col{flex:1;margin-left:10px;display:flex;flex-direction:column}.activity-top-row{display:flex;justify-content:space-between;align-items:center}.activity-item-title{font-size:13px;font-weight:700}.activity-item-title.checkin{color:#059669}.activity-item-title.checkout{color:var(--color-error)}.activity-time-wrapper{display:flex;font-size:12px;color:var(--color-text-secondary)}.time-day{color:var(--brand-800);font-weight:500}.time-date{color:var(--color-text-secondary);margin-left:4px}.time-hour{color:var(--color-text-primary);margin-left:4px;font-weight:600}.activity-location-row{display:flex;align-items:center;margin-top:5px;gap:8px}.activity-location-text{font-size:12px;color:var(--color-text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:250px}.resolved-loc-name{color:var(--color-primary);font-weight:700}.empty-state-view{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:24px 16px;background-color:var(--brand-50);text-align:center}.empty-icon-wrapper{width:48px;height:48px;border-radius:24px;background-color:var(--brand-100);display:flex;align-items:center;justify-content:center;margin-bottom:12px}.empty-title{font-family:Outfit,sans-serif;font-weight:700;font-size:14px;color:var(--color-text-primary);margin-bottom:4px}.empty-hint{font-size:12px;color:var(--color-text-secondary)}.attendance-detail-modal{display:flex;flex-direction:column;max-height:85%;overflow-y:auto;scrollbar-width:none;padding-top:10px}.attendance-detail-modal::-webkit-scrollbar{display:none}.modal-close-chevron{display:flex;align-items:center;justify-content:center;width:40px;height:24px;color:#94a3b8;margin:0 auto 12px;cursor:pointer;transition:color .15s ease,transform .15s ease;flex-shrink:0}.modal-close-chevron:hover{color:var(--brand-600);transform:translateY(2px)}.detail-title{font-family:Outfit,sans-serif;font-weight:700;font-size:16px;color:var(--brand-600);letter-spacing:.1em;text-transform:uppercase}.detail-date-row{display:flex;align-items:center;margin-top:10px;margin-bottom:24px;font-family:Outfit,sans-serif;font-size:14px}.detail-day{font-weight:700;color:var(--brand-800)}.detail-date{font-weight:700;color:#2b9adf;margin-left:6px}.detail-section{display:flex;flex-direction:column}.detail-section.checkout{margin-bottom:24px}.detail-section-header{display:flex;align-items:center;justify-content:space-between;width:100%;padding-bottom:4px}.detail-section-header.clickable{cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:8px;padding:4px 8px;margin-left:-8px;margin-right:-8px;transition:background-color .15s ease}.detail-section-header.clickable:hover{background-color:var(--brand-50)}.detail-section-header-right{display:flex;align-items:center}.detail-section-label{font-family:Outfit,sans-serif;font-weight:700;font-size:14px;white-space:nowrap}.detail-section-label.checkin{color:var(--color-success)}.detail-section-label.checkout{color:var(--color-error)}.detail-section-loc{font-family:Outfit,sans-serif;font-weight:700;font-size:14px;color:var(--brand-500);margin-left:8px;flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;padding-right:12px}.detail-section-time{font-family:Outfit,sans-serif;font-weight:700;font-size:14px;color:var(--color-text-secondary);white-space:nowrap}.detail-media-container{position:relative;width:100%;margin-top:12px;border-radius:12px;overflow:hidden;border:1px solid #cbd5e1;background-color:var(--brand-50)}.detail-media-large{width:100%;display:block;position:relative;overflow:hidden}.detail-media-large.photo-active{height:auto}.detail-media-large.map-active{height:250px}.detail-photo-large{width:100%;height:auto;display:block}.detail-map-large{width:100%;height:100%;border:none;background-color:#f1f5f9}.detail-media-small{position:absolute;right:16px;bottom:16px;width:90px;height:90px;border-radius:10px;overflow:hidden;box-shadow:0 4px 10px #00000040;border:1px solid #cbd5e1;cursor:pointer;z-index:10;background-color:#fff;transition:transform .2s cubic-bezier(.16,1,.3,1)}.detail-media-small:active{transform:scale(.95)}.detail-photo-small{width:100%;height:100%;object-fit:cover}.detail-map-small{width:100%;height:100%;border:none;pointer-events:none}.detail-share-btn{position:absolute;top:16px;right:16px;width:42px;height:42px;border-radius:50%;background-color:#f59e0b;border:none;display:flex;align-items:center;justify-content:center;cursor:pointer;z-index:10;box-shadow:0 2px 5px #0003;transition:transform .15s ease,background-color .15s ease}.detail-share-btn:active{transform:scale(.9);background-color:#d97706}.spinner-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#ffffffb3;display:flex;align-items:center;justify-content:center;z-index:5}.wap-root{display:flex;flex-direction:column;height:100%;background-color:#121212;color:#fff;position:relative}.wap-header{height:64px;display:flex;align-items:center;justify-content:space-between;padding:0 16px;background-color:var(--brand-900);border-bottom:1px solid rgba(255,255,255,.1);z-index:10;box-shadow:0 2px 8px #0000004d}.wap-back-btn,.wap-share-btn{background:none;border:none;width:44px;height:44px;border-radius:50%;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s,color .2s,box-shadow .2s}.wap-back-btn{color:#fff}.wap-share-btn{color:#fbbf24;background-color:#fbbf2429;box-shadow:0 0 0 1px #fbbf2447}.wap-back-btn:active,.wap-share-btn:active{background-color:#ffffff1a}.wap-share-btn:active{background-color:#fbbf2447}.wap-title{font-family:Outfit,sans-serif;font-weight:600;font-size:18px;color:#fff;text-align:center;flex:1}.wap-content{flex:1;display:flex;align-items:center;justify-content:center;padding:24px;overflow:hidden}.wap-image-wrapper{width:100%;height:100%;display:flex;align-items:center;justify-content:center;border-radius:var(--border-radius);overflow:hidden;box-shadow:0 10px 25px #00000080;background-color:#1a1a1a}.wap-preview-img{max-width:100%;max-height:100%;object-fit:contain}.wap-empty-state{display:flex;align-items:center;justify-content:center;font-size:16px;color:var(--color-text-secondary)}.wap-modal-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background-color:#0009;z-index:100;display:flex;align-items:flex-end;justify-content:center}.wap-modal-content{background-color:#fff;border-top-left-radius:20px;border-top-right-radius:20px;width:100%;max-width:440px;padding:24px;box-sizing:border-box;color:var(--color-text-primary);box-shadow:0 -4px 20px #00000040}.wap-modal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.wap-modal-header h3{font-family:Outfit,sans-serif;font-weight:700;font-size:18px;color:var(--color-primary-dark)}.wap-modal-close{background:none;border:none;font-size:28px;color:var(--color-text-secondary);cursor:pointer;line-height:1}.wap-modal-desc{font-size:14px;color:var(--color-text-secondary);line-height:1.5;margin-bottom:20px}.wap-share-actions{display:flex;flex-direction:column;gap:12px}.wap-action-row{display:flex;align-items:center;padding:14px 16px;background-color:var(--brand-50);border:1px solid var(--brand-100);border-radius:12px;text-decoration:none;color:var(--color-text-primary);transition:background-color .15s,transform .1s;cursor:pointer}.wap-action-row:active{transform:scale(.98);background-color:var(--brand-100)}.wap-action-icon-wrapper{width:44px;height:44px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;margin-right:14px;flex-shrink:0}.wap-action-icon-wrapper.download{background-color:var(--color-primary)}.wap-action-icon-wrapper.copy{background-color:var(--color-accent)}.wap-action-text-wrapper{display:flex;flex-direction:column;text-align:left}.wap-action-label{font-family:Outfit,sans-serif;font-weight:600;font-size:15px;color:var(--color-text-primary)}.wap-action-sublabel{font-size:12px;color:var(--color-text-secondary);margin-top:2px}.wap-modal-error{margin-top:12px;color:var(--color-error);font-size:13px;text-align:center}.button-reset{background:none;border:none;font-family:inherit;width:100%}.animate-slide-up{animation:slideUp .3s cubic-bezier(.16,1,.3,1)}@keyframes slideUp{0%{transform:translateY(100%)}to{transform:translateY(0)}}
