@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&display=swap";.sidebar{position:fixed;left:0;top:0;height:100vh;background-color:var(--sidebar-bg);border-right:1px solid var(--sidebar-border);display:flex;flex-direction:column;z-index:var(--z-fixed);box-shadow:var(--shadow-sm);overflow:visible}.sidebar-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);border-bottom:1px solid var(--color-border);min-height:70px}.sidebar-logo{flex:1;display:flex;align-items:center;font-weight:var(--font-weight-bold);font-size:var(--font-size-xl);color:var(--color-primary)}.sidebar-logo-text{white-space:nowrap;letter-spacing:-.5px}.sidebar-logo-icon{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold)}.sidebar-toggle{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-base);background-color:transparent;color:var(--color-text-secondary);transition:all var(--transition-fast);cursor:pointer}.sidebar-toggle:hover{background-color:var(--color-background-alt);color:var(--color-primary)}.sidebar-nav{flex:1;overflow-y:auto;overflow-x:hidden;padding:var(--space-2) 0}.sidebar-menu{list-style:none;padding:0;margin:0}.sidebar-menu li{margin-bottom:4px}.sidebar-item{display:flex;align-items:center;gap:var(--space-2);padding:12px var(--space-3);color:var(--color-text-secondary);text-decoration:none;transition:all var(--transition-fast);cursor:pointer;width:100%;background:none;border:none;border-left:3px solid transparent;text-align:left;font-size:var(--font-size-base)}.sidebar-item:hover{background-color:var(--sidebar-item-hover);color:var(--color-primary)}.sidebar-item-active{background-color:var(--sidebar-item-hover);color:var(--sidebar-item-active);border-left-color:var(--color-primary);font-weight:var(--font-weight-medium)}.sidebar-item-icon{display:flex;align-items:center;justify-content:center;min-width:20px}.sidebar-item-label{white-space:nowrap;overflow:hidden}.sidebar-collapsed .sidebar-header{justify-content:center;padding:var(--space-3) var(--space-1)}.sidebar-collapsed .sidebar-toggle{position:absolute;right:-16px;top:24px;background-color:var(--color-surface);border:1px solid var(--color-border);box-shadow:var(--shadow-sm)}.sidebar-collapsed .sidebar-item{justify-content:center;padding:12px var(--space-1)}.sidebar-user{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-3);border-top:1px solid var(--color-border);background:var(--color-background-alt)}.sidebar-user-avatar{width:40px;height:40px;min-width:40px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;overflow:hidden}.sidebar-user-avatar img{width:100%;height:100%;object-fit:cover}.sidebar-user-avatar span{color:var(--color-text-on-primary);font-weight:var(--font-weight-bold);font-size:var(--font-size-lg)}.sidebar-user-info{display:flex;flex-direction:column;gap:2px;overflow:hidden}.sidebar-user-name{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-location{display:flex;align-items:center;gap:4px;color:var(--color-text-tertiary);font-size:var(--font-size-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sidebar-user-role{color:var(--color-primary);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:capitalize}.sidebar-collapsed .sidebar-user{justify-content:center;padding:var(--space-2)}.sidebar-collapsed .sidebar-user-avatar{width:36px;height:36px;min-width:36px}.sidebar-footer{border-top:1px solid var(--color-border);padding:var(--space-2)}.sidebar-logout{color:var(--color-error)}.sidebar-logout:hover{background-color:var(--color-error-light);color:var(--color-error)}.sidebar-overlay{display:none}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform var(--transition-base);width:var(--sidebar-width)!important}.sidebar:not(.sidebar-collapsed){transform:translate(0)}.sidebar.sidebar-collapsed{transform:translate(-100%)}.sidebar-overlay{display:block;position:fixed;top:0;left:0;right:0;bottom:0;background-color:rgba(0,0,0,.5);z-index:calc(var(--z-fixed) - 1)}.sidebar-toggle{display:flex}.sidebar-header{padding:var(--space-2);min-height:60px}.sidebar-item{padding:var(--space-2) var(--space-2)}.sidebar-user{padding:var(--space-2)}.sidebar-user-avatar{width:36px;height:36px;min-width:36px}.sidebar-footer{padding:var(--space-1)}}.sidebar-nav::-webkit-scrollbar{width:4px}.sidebar-nav::-webkit-scrollbar-track{background:transparent}.sidebar-nav::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-base)}.sidebar-nav::-webkit-scrollbar-thumb:hover{background:var(--color-border-dark)}.main-layout{display:flex;min-height:100vh;background-color:var(--color-background);width:100%;max-width:100vw;overflow-x:hidden}.main-content{flex:1;margin-left:var(--sidebar-width);padding:var(--space-4);transition:margin-left var(--transition-base);min-height:100vh;background-color:var(--color-background-alt);max-width:calc(100vw - var(--sidebar-width));overflow-x:hidden}.main-content-expanded{margin-left:var(--sidebar-collapsed-width);max-width:calc(100vw - var(--sidebar-collapsed-width))}.mobile-menu-btn{display:none;position:fixed;top:var(--space-2);left:var(--space-2);z-index:calc(var(--z-fixed) - 2);width:44px;height:44px;background:var(--color-primary);color:var(--color-text-on-primary);border:none;border-radius:var(--radius-base);cursor:pointer;align-items:center;justify-content:center;box-shadow:var(--shadow-md)}.mobile-menu-btn:hover{background:var(--color-primary-dark)}@media(max-width:768px){.main-content{margin-left:0;padding:var(--space-2);padding-top:calc(var(--space-2) + 60px);max-width:100vw;width:100%}.main-content-expanded{margin-left:0;max-width:100vw}.mobile-menu-btn{display:flex}}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-1);font-family:var(--font-family);font-weight:var(--font-weight-medium);border-radius:var(--radius-base);border:none;cursor:pointer;transition:all var(--transition-fast);position:relative;white-space:nowrap;user-select:none}.btn:focus-visible{outline:2px solid var(--color-primary);outline-offset:2px}.btn-small{padding:6px 12px;font-size:var(--font-size-sm);height:32px}.btn-medium{padding:10px 20px;font-size:var(--font-size-base);height:40px}.btn-large{padding:14px 28px;font-size:var(--font-size-lg);height:48px}.btn-primary{background-color:var(--color-primary);color:var(--color-text-on-primary)}.btn-primary:hover:not(.btn-disabled){background-color:var(--color-primary-dark);box-shadow:var(--shadow-sm)}.btn-secondary{background-color:var(--color-secondary);color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-secondary:hover:not(.btn-disabled){background-color:var(--color-secondary-dark);border-color:var(--color-border-dark)}.btn-outline{background-color:transparent;color:var(--color-primary);border:1px solid var(--color-primary)}.btn-outline:hover:not(.btn-disabled){background-color:var(--color-primary-lighter)}.btn-ghost{background-color:transparent;color:var(--color-text-primary)}.btn-ghost:hover:not(.btn-disabled){background-color:var(--color-background-alt)}.btn-danger{background-color:var(--color-error);color:var(--color-text-on-primary)}.btn-danger:hover:not(.btn-disabled){background-color:#a82828;box-shadow:var(--shadow-sm)}.btn-success{background-color:var(--color-success);color:var(--color-text-on-primary)}.btn-success:hover:not(.btn-disabled){background-color:#256640;box-shadow:var(--shadow-sm)}.btn-disabled{opacity:.5;cursor:not-allowed;pointer-events:none}.btn-full{width:100%}.btn-icon{display:inline-flex;align-items:center;justify-content:center}.btn-icon svg{width:18px;height:18px}.btn-spinner{width:16px;height:16px;border:2px solid currentColor;border-top-color:transparent;border-radius:50%;animation:spin .6s linear infinite}.input-wrapper{display:flex;flex-direction:column;gap:6px;width:100%}.input-wrapper.input-full{width:100%}.input-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.input-required{color:var(--color-error);margin-left:4px}.input-container{position:relative;display:flex;align-items:center}.input-field{width:100%;padding:10px 14px;font-size:var(--font-size-base);font-family:var(--font-family);color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);transition:all var(--transition-fast);height:40px}.input-field.input-with-icon{padding-left:40px}.input-field:hover:not(:disabled){border-color:var(--color-border-dark)}.input-field:focus{border-color:var(--color-primary);box-shadow:0 0 0 3px var(--color-primary-lighter)}.input-field::placeholder{color:var(--color-text-tertiary)}.input-field:disabled{background-color:var(--color-background-alt);color:var(--color-text-tertiary);cursor:not-allowed}.input-icon{position:absolute;left:12px;display:flex;align-items:center;justify-content:center;color:var(--color-text-tertiary);pointer-events:none}.input-icon svg{width:18px;height:18px}.input-helper{font-size:var(--font-size-xs);color:var(--color-text-secondary)}.input-helper-error{color:var(--color-error)}.input-wrapper.input-error .input-field{border-color:var(--color-error)}.input-wrapper.input-error .input-field:focus{box-shadow:0 0 0 3px var(--color-error-light)}.input-wrapper.input-disabled{opacity:.6}textarea.input-field{min-height:100px;resize:vertical;padding:10px 14px}select.input-field{cursor:pointer;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%237A7A7A' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px;-webkit-appearance:none;appearance:none}.auth-container{min-height:100vh;display:flex;align-items:center;justify-content:center;position:relative;overflow:hidden;background:linear-gradient(135deg,var(--color-background) 0%,var(--color-secondary) 100%)}.auth-card{position:relative;z-index:1;width:100%;max-width:450px;margin:var(--space-3);padding:var(--space-6);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);box-shadow:var(--shadow-xl)}.auth-header{text-align:center;margin-bottom:var(--space-4)}.auth-logo{display:inline-flex;align-items:center;justify-content:center;width:70px;height:70px;margin-bottom:var(--space-3);background:var(--color-primary);color:var(--color-text-on-primary);font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);border-radius:var(--radius-base);box-shadow:var(--shadow-md)}.auth-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin-bottom:var(--space-1)}.auth-subtitle{font-size:var(--font-size-base);color:var(--color-text-secondary)}.auth-form{display:flex;flex-direction:column;gap:var(--space-3);margin-bottom:var(--space-3)}.auth-error{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2);background:var(--color-error-light);color:var(--color-error);border:1px solid var(--color-error);border-radius:var(--radius-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.auth-options{display:flex;align-items:center;justify-content:space-between;margin-top:calc(var(--space-1) * -1)}.auth-checkbox{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer}.auth-checkbox input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:var(--color-primary)}.auth-link{font-size:var(--font-size-sm);color:var(--color-primary);font-weight:var(--font-weight-medium);transition:color var(--transition-fast)}.auth-link:hover{color:var(--color-primary-dark);text-decoration:underline}.auth-footer{text-align:center;padding-top:var(--space-3);border-top:1px solid var(--color-border);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-background{position:absolute;top:0;left:0;right:0;bottom:0;overflow:hidden;z-index:0;pointer-events:none}.auth-bg-shape{position:absolute;border-radius:var(--radius-base);opacity:.08}.auth-bg-shape-1{width:400px;height:400px;background:var(--color-primary);top:-100px;right:-100px;transform:rotate(45deg)}.auth-bg-shape-2{width:300px;height:300px;background:var(--color-primary-dark);bottom:-80px;left:-80px;transform:rotate(25deg)}.auth-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-2)}@media(max-width:768px){.auth-card{padding:var(--space-4)}.auth-form-row{grid-template-columns:1fr}.auth-bg-shape-1,.auth-bg-shape-2{opacity:.05}}.card{background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);box-shadow:var(--shadow-sm)}.card-padding-none .card-body{padding:0}.card-padding-small .card-body{padding:var(--space-2)}.card-padding-medium .card-body{padding:var(--space-3)}.card-padding-large .card-body{padding:var(--space-4)}.card-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-3);border-bottom:1px solid var(--color-border-light)}.card-header-text{flex:1}.card-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.card-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:var(--space-1) 0 0}.card-header-action{margin-left:var(--space-2)}.badge{display:inline-flex;align-items:center;font-weight:var(--font-weight-medium);border-radius:var(--radius-sm);white-space:nowrap}.badge-small{padding:2px 6px;font-size:var(--font-size-xs)}.badge-medium{padding:4px 10px;font-size:var(--font-size-xs)}.badge-large{padding:6px 12px;font-size:var(--font-size-sm)}.badge-default{background-color:var(--color-secondary);color:var(--color-text-secondary)}.badge-primary{background-color:var(--color-primary-lighter);color:var(--color-primary-dark)}.dashboard{display:flex;flex-direction:column;gap:var(--space-3)}.dashboard-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-2)}.dashboard-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.dashboard-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:var(--space-1) 0 0}.dashboard-header-right{display:flex;gap:var(--space-2)}.dashboard-time{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);font-family:monospace;color:var(--color-primary);background:var(--color-primary-lighter);padding:var(--space-1) var(--space-2);border-radius:var(--radius-base)}.dashboard-date{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary);background:var(--color-surface);padding:var(--space-1) var(--space-2);border-radius:var(--radius-base);border:1px solid var(--color-border)}.stats-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}.stat-card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);padding:var(--space-3);transition:all var(--transition-fast)}.stat-card-clickable{cursor:pointer}.stat-card-clickable:hover{box-shadow:var(--shadow-md);border-color:var(--color-primary)}.stat-card-header{margin-bottom:var(--space-2)}.stat-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-base)}.stat-icon-primary{background:var(--color-primary-lighter);color:var(--color-primary)}.stat-icon-success{background:var(--color-success-light);color:var(--color-success)}.stat-icon-error{background:var(--color-error-light);color:var(--color-error)}.stat-icon-warning{background:var(--color-warning-light);color:var(--color-warning)}.stat-icon-info{background:var(--color-info-light);color:var(--color-info)}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.stat-title{font-size:var(--font-size-sm);color:var(--color-text-secondary);margin:var(--space-1) 0 0}.stat-subtitle{font-size:var(--font-size-xs);color:var(--color-text-tertiary);margin:0}.stats-row{display:flex;gap:var(--space-4);padding:var(--space-2) var(--space-3);background:var(--color-background-alt);border-radius:var(--radius-base);border:1px solid var(--color-border)}.stat-inline{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.stat-inline svg{color:var(--color-text-tertiary)}.stat-inline strong{color:var(--color-text-primary)}.dashboard-grid{display:grid;grid-template-columns:1.5fr 1fr;gap:var(--space-3)}.dashboard-right{display:flex;flex-direction:column;gap:var(--space-3)}.activity-list{display:flex;flex-direction:column;gap:var(--space-2);max-height:350px;overflow-y:auto}.activity-empty{text-align:center;padding:var(--space-4);color:var(--color-text-tertiary)}.activity-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--color-background-alt);border-radius:var(--radius-base)}.activity-icon{width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-base);flex-shrink:0}.activity-in{background:var(--color-success-light);color:var(--color-success)}.activity-out{background:var(--color-warning-light);color:var(--color-warning)}.activity-content{flex:1;min-width:0}.activity-name{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.activity-detail{display:block;font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.activity-time{font-size:var(--font-size-xs);color:var(--color-text-tertiary);white-space:nowrap}.working-list{display:flex;flex-direction:column;gap:var(--space-2)}.working-empty{text-align:center;padding:var(--space-3);color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.working-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--color-background-alt);border-radius:var(--radius-base)}.working-avatar{width:36px;height:36px;background:var(--color-primary);color:var(--color-text-on-primary);border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm);flex-shrink:0;overflow:hidden}.working-avatar img{width:100%;height:100%;object-fit:cover}.working-info{flex:1;min-width:0}.working-name{display:block;font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.working-since{display:block;font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.payroll-list{display:flex;flex-direction:column;gap:var(--space-2)}.payroll-item{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2);background:var(--color-background-alt);border-radius:var(--radius-base)}.payroll-info{display:flex;flex-direction:column}.payroll-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-sm)}.payroll-amount{font-size:var(--font-size-xs);color:var(--color-success);font-weight:var(--font-weight-semibold)}.quick-actions{display:flex;flex-direction:column;gap:var(--space-2)}.view-all-btn{margin-top:var(--space-2)}@media(max-width:1200px){.stats-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:1024px){.dashboard-grid{grid-template-columns:1fr}.dashboard-right{display:grid;grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.dashboard-header{flex-direction:column;align-items:stretch;text-align:center}.dashboard-header-right{justify-content:center}.stats-row{flex-direction:column;gap:var(--space-2);align-items:center}.dashboard-right{grid-template-columns:1fr}}@media(max-width:480px){.dashboard-title{font-size:var(--font-size-xl)}.stats-grid{grid-template-columns:1fr}.stat-card{padding:var(--space-2)}.stat-icon{width:40px;height:40px}.stat-value{font-size:var(--font-size-xl)}.dashboard-time{font-size:var(--font-size-base)}.activity-item{flex-wrap:wrap}.activity-time{width:100%;text-align:right;margin-top:var(--space-1)}}.scan-page{display:flex;flex-direction:column;gap:var(--space-3);max-width:500px;margin:0 auto}.scan-header{background:var(--color-primary);color:var(--color-text-on-primary);padding:var(--space-3);border-radius:var(--radius-base);text-align:center}.scan-header-info{display:flex;flex-direction:column;align-items:center;gap:var(--space-2)}.scan-time-display{display:flex;align-items:center;gap:var(--space-2)}.time-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);font-family:monospace}.scan-location-display{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);opacity:.9}.scan-content{display:flex;flex-direction:column;gap:var(--space-3)}.scan-alert{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);border-radius:var(--radius-base);font-weight:var(--font-weight-medium)}.scan-alert-error{background:var(--color-error-light);color:var(--color-error);border:1px solid var(--color-error)}.alert-close{margin-left:auto;background:none;border:none;font-size:var(--font-size-xl);cursor:pointer;color:inherit;opacity:.7;line-height:1}.alert-close:hover{opacity:1}.scan-input-section{display:flex;flex-direction:column;gap:var(--space-3)}.manual-input-card h3{margin:0 0 var(--space-2);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.manual-form{display:flex;gap:var(--space-2)}.manual-form .input-wrapper{flex:1}.scan-divider{display:flex;align-items:center;gap:var(--space-2);color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.scan-divider:before,.scan-divider:after{content:"";flex:1;height:1px;background:var(--color-border)}.scanner-card{overflow:hidden}.scanner-area{position:relative;width:100%;aspect-ratio:1;background:var(--color-background-dark);border-radius:var(--radius-base);overflow:hidden;margin-bottom:var(--space-2)}#qr-reader{width:100%;height:100%}.scanner-active{display:block}.scanner-hidden{display:none}.scanner-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-2);color:var(--color-text-tertiary)}.scanner-placeholder p{margin:0;font-size:var(--font-size-sm)}.scanner-controls{display:flex}.scan-confirm-card{background:var(--color-surface);border:2px solid var(--color-primary);border-radius:var(--radius-base);padding:var(--space-3);box-shadow:var(--shadow-md)}.confirm-header{text-align:center;margin-bottom:var(--space-3)}.confirm-header h3{margin:0;font-size:var(--font-size-lg);color:var(--color-primary)}.confirm-employee{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--color-background-alt);border-radius:var(--radius-base);margin-bottom:var(--space-3)}.confirm-avatar{width:70px;height:70px;border-radius:var(--radius-base);background:var(--color-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.confirm-avatar img{width:100%;height:100%;object-fit:cover}.confirm-avatar span{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-on-primary)}.confirm-info h2{margin:0 0 var(--space-1);font-size:var(--font-size-xl);color:var(--color-text-primary)}.confirm-code{margin:0;font-family:monospace;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.confirm-position{margin:var(--space-1) 0 0;font-size:var(--font-size-sm);color:var(--color-text-secondary)}.confirm-details{display:flex;flex-direction:column;gap:var(--space-1);margin-bottom:var(--space-3);padding:var(--space-2);background:var(--color-background-alt);border-radius:var(--radius-base)}.confirm-detail-row{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.confirm-detail-row svg{color:var(--color-text-tertiary);flex-shrink:0}.confirm-action-preview{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2);margin-bottom:var(--space-3)}.action-preview-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);font-size:var(--font-size-base)}.action-time{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}.confirm-actions{display:flex;gap:var(--space-2)}.confirm-actions button{flex:1}.scan-success-card{background:var(--color-surface);border-radius:var(--radius-base);overflow:hidden;box-shadow:var(--shadow-md)}.success-banner{display:flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-3);font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-on-primary)}.banner-in{background:var(--color-success)}.banner-out{background:var(--color-warning)}.success-employee{display:flex;flex-direction:column;align-items:center;padding:var(--space-3);text-align:center}.success-avatar{width:80px;height:80px;border-radius:var(--radius-base);background:var(--color-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:var(--space-2)}.success-avatar img{width:100%;height:100%;object-fit:cover}.success-avatar span{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-on-primary)}.success-employee h2{margin:0;font-size:var(--font-size-xl);color:var(--color-text-primary)}.employee-code-display{margin:var(--space-1) 0 0;font-family:monospace;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.success-time{display:flex;align-items:center;justify-content:center;gap:var(--space-1);padding:var(--space-2);background:var(--color-background-alt);color:var(--color-text-secondary);font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold)}.scan-success-card>button{margin:var(--space-3);margin-top:0}#qr-reader video{border-radius:var(--radius-base)}#qr-reader__dashboard_section_swaplink{display:none!important}#qr-reader__dashboard_section{padding:0!important}@media(max-width:480px){.scan-page{padding:0 var(--space-2)}.time-value{font-size:var(--font-size-xl)}.manual-form{flex-direction:column}.confirm-employee{flex-direction:column;text-align:center}.confirm-actions{flex-direction:column}}.loader-container{display:flex;align-items:center;justify-content:center;padding:var(--space-6)}.loader-fullscreen{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:var(--color-background);z-index:9999}.boxes{--size: 32px;--duration: .8s;height:calc(var(--size) * 2);width:calc(var(--size) * 3);position:relative;transform-style:preserve-3d;transform-origin:50% 50%;transform:rotateX(60deg) rotate(45deg) rotateY(0) translateZ(0)}.boxes .box{width:var(--size);height:var(--size);top:0;left:0;position:absolute;transform-style:preserve-3d}.boxes .box:nth-child(1){transform:translate(100%);animation:box1 var(--duration) linear infinite}.boxes .box:nth-child(2){transform:translateY(100%);animation:box2 var(--duration) linear infinite}.boxes .box:nth-child(3){transform:translate(100%,100%);animation:box3 var(--duration) linear infinite}.boxes .box:nth-child(4){transform:translate(200%);animation:box4 var(--duration) linear infinite}.boxes .box>div{--background: var(--color-primary);--top: auto;--right: auto;--bottom: auto;--left: auto;--translateZ: calc(var(--size) / 2);--rotateY: 0deg;--rotateX: 0deg;position:absolute;width:100%;height:100%;background:var(--background);top:var(--top);right:var(--right);bottom:var(--bottom);left:var(--left);transform:rotateY(var(--rotateY)) rotateX(var(--rotateX)) translateZ(var(--translateZ))}.boxes .box>div:nth-child(1){--top: 0;--left: 0}.boxes .box>div:nth-child(2){--background: var(--color-primary-dark);--right: 0;--rotateY: 90deg}.boxes .box>div:nth-child(3){--background: #E85454;--rotateX: -90deg}.boxes .box>div:nth-child(4){--background: var(--color-background-alt);--top: 0;--left: 0;--translateZ: calc(var(--size) * 3 * -1)}@keyframes box1{0%,50%{transform:translate(100%)}to{transform:translate(200%)}}@keyframes box2{0%{transform:translateY(100%)}50%{transform:translate(0)}to{transform:translate(100%)}}@keyframes box3{0%,50%{transform:translate(100%,100%)}to{transform:translateY(100%)}}@keyframes box4{0%{transform:translate(200%)}50%{transform:translate(200%,100%)}to{transform:translate(100%,100%)}}.table-container{width:100%;overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-base)}.table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.table-header{background-color:var(--color-background-alt)}.table-th{padding:var(--space-2) var(--space-2);text-align:left;font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);border-bottom:1px solid var(--color-border);white-space:nowrap}.table-th-sortable{cursor:pointer;user-select:none;transition:background-color var(--transition-fast)}.table-th-sortable:hover{background-color:var(--color-secondary-dark)}.table-th-content{display:flex;align-items:center;gap:var(--space-1)}.table-sort-icon{display:flex;align-items:center;color:var(--color-primary)}.table-sort-inactive{opacity:.3}.table-body{background-color:var(--color-surface)}.table-row{border-bottom:1px solid var(--color-border-light);transition:background-color var(--transition-fast)}.table-row:last-child{border-bottom:none}.table-row:hover{background-color:var(--color-surface-hover)}.table-row-clickable{cursor:pointer}.table-row-selected{background-color:var(--color-primary-lighter)}.table-td{padding:var(--space-2);color:var(--color-text-primary);vertical-align:middle}.table-loading,.table-empty{padding:var(--space-6);text-align:center;color:var(--color-text-tertiary)}.table-spinner{display:inline-block;width:20px;height:20px;border:2px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:table-spin .8s linear infinite;margin-right:var(--space-1)}@keyframes table-spin{to{transform:rotate(360deg)}}@media(max-width:768px){.table{font-size:var(--font-size-xs)}.table-th,.table-td{padding:var(--space-1)}.table-th{font-size:var(--font-size-xs)}}@media(max-width:480px){.table-container{border-radius:var(--radius-sm)}.table-loading,.table-empty{padding:var(--space-4);font-size:var(--font-size-xs)}}.modal-container{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-2)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background-color:rgba(0,0,0,.5);z-index:var(--z-modal-backdrop)}.modal{position:relative;background-color:var(--color-surface);border-radius:var(--radius-base);box-shadow:var(--shadow-xl);z-index:var(--z-modal);max-height:90vh;display:flex;flex-direction:column;width:100%}.modal-small{max-width:400px}.modal-medium{max-width:560px}.modal-large{max-width:800px}.modal-fullscreen{max-width:95vw;max-height:95vh}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-3);border-bottom:1px solid var(--color-border-light)}.modal-title{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.modal-close{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border:none;background:none;color:var(--color-text-tertiary);cursor:pointer;border-radius:var(--radius-base);transition:all var(--transition-fast)}.modal-close:hover{background-color:var(--color-background-alt);color:var(--color-text-primary)}.modal-body{padding:var(--space-3);overflow-y:auto;flex:1}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-3);border-top:1px solid var(--color-border-light)}.select-wrapper{display:flex;flex-direction:column;gap:var(--space-1)}.select-full{width:100%}.select-label{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary)}.select-required{color:var(--color-error);margin-left:2px}.select-container{position:relative;display:flex;align-items:center}.select-field{width:100%;padding:10px 36px 10px 12px;font-size:var(--font-size-sm);color:var(--color-text-primary);background-color:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);cursor:pointer;-webkit-appearance:none;appearance:none;transition:all var(--transition-fast)}.select-field:hover:not(:disabled){border-color:var(--color-border-dark)}.select-field:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-lighter)}.select-icon{position:absolute;right:12px;color:var(--color-text-tertiary);pointer-events:none}.select-error .select-field{border-color:var(--color-error)}.select-error .select-field:focus{box-shadow:0 0 0 2px var(--color-error-light)}.select-disabled .select-field{background-color:var(--color-background-alt);cursor:not-allowed;opacity:.6}.select-helper{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.select-helper-error{color:var(--color-error)}.qr-container{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);box-shadow:var(--shadow-sm)}.code-type-toggle{display:flex;gap:var(--space-1);padding:4px;background:var(--color-background-alt);border-radius:var(--radius-base)}.toggle-btn{display:flex;align-items:center;gap:var(--space-1);padding:8px 16px;background:transparent;border:none;border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.toggle-btn:hover{color:var(--color-text-primary);background:var(--color-surface)}.toggle-btn.active{background:var(--color-surface);color:var(--color-primary);box-shadow:var(--shadow-sm)}.qr-wrapper{padding:var(--space-2);background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center}.qr-info{text-align:center}.qr-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin-bottom:4px}.qr-code{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);font-family:Courier New,monospace;letter-spacing:1px}.qr-download-btn{display:flex;align-items:center;gap:var(--space-1);padding:10px 20px;background-color:var(--color-primary);color:var(--color-text-on-primary);border:none;border-radius:var(--radius-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);cursor:pointer;transition:all var(--transition-fast)}.qr-download-btn:hover{background-color:var(--color-primary-dark);box-shadow:var(--shadow-sm)}.employee-badge-container{display:flex;flex-direction:column;align-items:center;gap:20px;padding:10px 0}.badge-controls{display:flex;justify-content:center}.code-type-toggle{display:inline-flex;background:#f3f4f6;border-radius:8px;padding:4px;gap:4px}.toggle-btn{display:flex;align-items:center;gap:6px;padding:8px 16px;border:none;background:transparent;border-radius:6px;cursor:pointer;font-size:13px;font-weight:600;color:#6b7280;transition:all .2s}.toggle-btn:hover{color:#374151;background:#e5e7eb}.toggle-btn.active{background:#c62828;color:#fff}.badge-card-wrapper{display:flex;justify-content:center}.badge-card{width:220px;height:350px;background:linear-gradient(175deg,#d32f2f,#c62828 30%,#b71c1c 70%,#7f1414);position:relative;display:flex;flex-direction:column;align-items:center;overflow:hidden;box-shadow:0 20px 40px rgba(0,0,0,.3)}.badge-card:before{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background-image:linear-gradient(rgba(255,255,255,.05) 1px,transparent 1px),linear-gradient(90deg,rgba(255,255,255,.05) 1px,transparent 1px);background-size:16px 16px;z-index:0;pointer-events:none}.badge-header{padding:16px 16px 10px;text-align:center;position:relative;z-index:1;width:100%}.badge-company{display:flex;flex-direction:column;align-items:center;gap:6px}.badge-logo-img{height:32px;width:auto}.badge-logo-text{font-size:18px;font-weight:800;color:#fff;letter-spacing:2px;text-transform:uppercase}.badge-company-subtitle{font-size:9px;color:rgba(255,255,255,.9);letter-spacing:1.5px;text-transform:uppercase;font-weight:600}.badge-photo-section{position:relative;z-index:1}.badge-photo-frame{width:100px;height:100px;background:#fff;padding:4px}.badge-photo{width:100%;height:100%;object-fit:cover;display:block}.badge-photo-placeholder{width:100%;height:100%;display:flex;align-items:center;justify-content:center;background:#e0e0e0}.badge-photo-placeholder span{font-size:40px;font-weight:800;color:#999}.badge-employee-info{padding:12px 16px 8px;text-align:center;position:relative;z-index:1;width:100%}.badge-employee-name{font-size:14px;font-weight:700;color:#fff;margin:0 0 4px;line-height:1.2}.badge-employee-position{font-size:11px;color:rgba(255,255,255,.9);margin:0;font-weight:500}.badge-code-section{position:relative;z-index:1;display:flex;flex-direction:column;align-items:center;padding:8px}.badge-qr{width:70px;height:70px;background:#fff;padding:6px;display:flex;align-items:center;justify-content:center}.badge-qr svg{width:58px!important;height:58px!important}.badge-barcode{background:#fff;padding:4px 8px;max-width:180px;overflow:hidden}.badge-barcode svg{max-width:100%;height:auto}.badge-employee-code{font-size:10px;font-weight:700;color:#fff;margin:8px 0 0;font-family:monospace;letter-spacing:1px}.badge-footer{padding:8px;text-align:center;position:relative;z-index:1}.badge-footer span{font-size:8px;color:rgba(255,255,255,.5);text-transform:uppercase;letter-spacing:1px}.badge-error{background:#fef2f2;color:#b91c1c;padding:12px 16px;border-radius:8px;font-size:14px;text-align:center;border:1px solid #fecaca}.badge-success{background:#ecfdf5;color:#047857;padding:10px 16px;border-radius:8px;font-size:14px;text-align:center;border:1px solid #a7f3d0}.badge-actions{display:flex;gap:12px;justify-content:center;flex-wrap:wrap}.badge-warning{font-size:12px;color:#9ca3af;text-align:center;font-style:italic}.spin{animation:spin 1s linear infinite}.employees-page{display:flex;flex-direction:column;gap:var(--space-4)}.search-box{position:relative;flex:1;max-width:320px}.employee-cell-avatar{width:36px;height:36px;border-radius:var(--radius-base);background:var(--color-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.employee-cell-avatar img{width:100%;height:100%;object-fit:cover}.action-btn-badge:hover{background:var(--color-primary-lighter);border-color:var(--color-primary);color:var(--color-primary)}.employee-form{display:flex;flex-direction:column;gap:var(--space-3)}.image-upload-section{display:flex;flex-direction:column;align-items:center;gap:var(--space-2);margin-bottom:var(--space-2)}.image-upload-preview{width:120px;height:120px;border-radius:var(--radius-base);border:2px dashed var(--color-border);background:var(--color-background-alt);cursor:pointer;position:relative;overflow:hidden;transition:all var(--transition-fast)}.image-upload-preview:hover{border-color:var(--color-primary);background:var(--color-primary-lighter)}.image-upload-preview img{width:100%;height:100%;object-fit:cover}.image-upload-placeholder{width:100%;height:100%;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);color:var(--color-text-tertiary)}.image-upload-placeholder span{font-size:var(--font-size-xs);text-align:center;padding:0 var(--space-1)}.image-upload-overlay{position:absolute;top:0;right:0;bottom:0;left:0;background:rgba(0,0,0,.6);display:flex;flex-direction:column;align-items:center;justify-content:center;gap:var(--space-1);color:#fff;opacity:0;transition:opacity var(--transition-fast)}.image-upload-preview:hover .image-upload-overlay{opacity:1}.image-upload-overlay span{font-size:var(--font-size-xs)}.image-error{color:var(--color-error);font-size:var(--font-size-xs)}.qr-modal-content{display:flex;justify-content:center;padding:var(--space-2)}.employees-section{margin-bottom:var(--space-4)}.employees-section:last-child{margin-bottom:0}.employees-section-title{font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary);margin:0 0 var(--space-2);padding-bottom:var(--space-2);border-bottom:1px solid var(--color-border-light)}@media(max-width:768px){.page-header,.table-toolbar{flex-direction:column;align-items:stretch}.search-box{max-width:none}.toolbar-actions{flex-direction:column}.toolbar-actions>*{width:100%}.image-upload-section{margin-bottom:var(--space-3)}.image-upload-preview{width:100px;height:100px}}@media(max-width:480px){.page-title{font-size:var(--font-size-xl)}.employee-cell-info{display:none}.employee-cell-avatar{width:32px;height:32px}.action-btn{width:28px;height:28px}.form-actions{flex-direction:column}.form-actions>*{width:100%}}.employee-cell-avatar.clickable{cursor:pointer;transition:transform .2s,box-shadow .2s}.employee-cell-avatar.clickable:hover{transform:scale(1.1);box-shadow:0 4px 12px rgba(0,0,0,.2)}.fullscreen-image-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:9999;cursor:pointer}.fullscreen-image-container{position:relative;max-width:90vw;max-height:90vh;display:flex;flex-direction:column;align-items:center}.fullscreen-image-container img{max-width:100%;max-height:80vh;object-fit:contain;border-radius:8px;box-shadow:0 20px 60px rgba(0,0,0,.5)}.fullscreen-image-name{color:#fff;font-size:18px;font-weight:600;margin-top:16px;text-align:center}.fullscreen-close-btn{position:absolute;top:-40px;right:-40px;width:40px;height:40px;border:none;background:rgba(255,255,255,.1);color:#fff;font-size:28px;cursor:pointer;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:background .2s}.fullscreen-close-btn:hover{background:rgba(255,255,255,.2)}.attendance-page{display:flex;flex-direction:column;gap:var(--space-4)}.header-actions{display:flex;gap:var(--space-2)}.stats-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.stat-item{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);padding:var(--space-2) var(--space-3);display:flex;flex-direction:column;gap:4px;min-width:150px}.stat-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:var(--font-size-xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.stat-value-success{color:var(--color-success)}.stat-value-warning{color:var(--color-warning)}.table-toolbar{display:flex;justify-content:space-between;align-items:center;gap:var(--space-2);margin-bottom:var(--space-3);flex-wrap:wrap}.toolbar-info{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.toolbar-actions{display:flex;gap:var(--space-2)}.time-cell{display:flex;align-items:center;gap:var(--space-1)}.time-icon{flex-shrink:0}.time-icon-in{color:var(--color-success)}.time-icon-out{color:var(--color-error)}.time-pending{color:var(--color-warning);font-size:var(--font-size-sm);font-style:italic}.table-actions{display:flex;gap:var(--space-1)}.action-btn{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:none;border:1px solid var(--color-border);border-radius:var(--radius-base);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.action-btn:hover{background:var(--color-background-alt);border-color:var(--color-border-dark);color:var(--color-text-primary)}.action-btn-danger:hover{background:var(--color-error-light);border-color:var(--color-error);color:var(--color-error)}.attendance-form{display:flex;flex-direction:column;gap:var(--space-3)}.form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.edit-employee-info{padding-bottom:var(--space-3);margin-bottom:var(--space-3);border-bottom:1px solid var(--color-border-light)}.stat-item{display:flex;align-items:center;gap:var(--space-2)}.stat-icon{width:40px;height:40px;border-radius:var(--radius-base);background:var(--color-primary-lighter);color:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.stat-item-warning .stat-icon{background:var(--color-warning-light);color:var(--color-warning)}.stat-item-success .stat-icon{background:var(--color-success-light);color:var(--color-success)}@media(max-width:768px){.page-header{flex-direction:column;align-items:stretch}.header-actions{flex-direction:column;width:100%}.header-actions>*{width:100%}.stats-row{flex-direction:column}.stat-item{min-width:auto;width:100%}.table-toolbar{flex-direction:column;align-items:stretch}.toolbar-info{justify-content:center}.form-row{grid-template-columns:1fr}.btn-text{display:inline}}@media(max-width:480px){.page-title{font-size:var(--font-size-xl)}.employee-cell-info{display:none}.employee-cell-avatar{width:32px;height:32px}.action-btn{width:28px;height:28px}.stat-value{font-size:var(--font-size-lg)}.stat-label{font-size:10px}}.locations-page{display:flex;flex-direction:column;gap:var(--space-4)}.search-section{display:flex;gap:var(--space-2)}.search-box{position:relative;flex:1;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--color-text-tertiary)}.search-input{width:100%;padding:10px 12px 10px 40px;font-size:var(--font-size-sm);border:1px solid var(--color-border);border-radius:var(--radius-base);background:var(--color-surface);color:var(--color-text-primary);transition:all var(--transition-fast)}.search-input:focus{outline:none;border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-lighter)}.locations-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-3)}.location-card{display:flex;flex-direction:column;gap:var(--space-2)}.location-header{display:flex;justify-content:space-between;align-items:flex-start}.location-icon{width:48px;height:48px;background:var(--color-primary-lighter);color:var(--color-primary);border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center}.location-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.location-address,.location-capacity{display:flex;align-items:flex-start;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.location-address svg,.location-capacity svg{flex-shrink:0;margin-top:2px}.location-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-light)}.btn-danger-outline:hover{background:var(--color-error-light)}.location-form{display:flex;flex-direction:column;gap:var(--space-3)}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.form-full-width{grid-column:1 / -1}@media(max-width:600px){.form-grid{grid-template-columns:1fr}}.payroll-page{display:flex;flex-direction:column;gap:var(--space-4)}.page-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.payroll-controls{display:flex;justify-content:space-between;align-items:flex-end;gap:var(--space-3);flex-wrap:wrap}.payroll-controls-left{display:flex;align-items:flex-end;gap:var(--space-3)}.payroll-controls-right{display:flex;align-items:center;gap:var(--space-2)}.payroll-controls-actions{display:flex;align-items:flex-end}.generate-form{display:flex;flex-direction:column;gap:var(--space-3)}.generate-inputs{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:var(--space-3);align-items:end}.generate-action{display:flex;align-items:flex-end}.payroll-result{background:var(--color-background-alt);border-radius:var(--radius-base);padding:var(--space-3);border:1px solid var(--color-border);margin-top:var(--space-3)}.result-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-3);padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-light);flex-wrap:wrap;gap:var(--space-2)}.result-header-actions{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.result-employee{display:flex;align-items:center;gap:var(--space-2)}.result-avatar{width:48px;height:48px;background:var(--color-primary);color:var(--color-text-on-primary);border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center;font-size:var(--font-size-lg);font-weight:var(--font-weight-bold);overflow:hidden;flex-shrink:0}.result-avatar img{width:100%;height:100%;object-fit:cover}.result-employee h3{margin:0;font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.result-employee p{margin:0;font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.result-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3);margin-bottom:var(--space-3)}.result-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);background:var(--color-surface);border-radius:var(--radius-base);border:1px solid var(--color-border-light)}.result-item svg{color:var(--color-text-tertiary);flex-shrink:0}.result-item>div{display:flex;flex-direction:column}.result-label{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase;letter-spacing:.5px}.result-value{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.text-warning{color:var(--color-warning)}.employee-cell{display:flex;align-items:center;gap:var(--space-2)}.employee-cell-avatar{width:36px;height:36px;border-radius:var(--radius-base);background:var(--color-primary);display:flex;align-items:center;justify-content:center;flex-shrink:0}.employee-cell-avatar span{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-on-primary)}.employee-cell-info{display:flex;flex-direction:column}.employee-cell-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.employee-cell-code{font-size:var(--font-size-xs);color:var(--color-text-tertiary);font-family:monospace}.table-actions{display:flex;gap:var(--space-1);flex-wrap:wrap;align-items:center}.table-actions button[title]{padding:var(--space-1)}.settings-form,.payroll-detail{display:flex;flex-direction:column;gap:var(--space-3)}.detail-header{text-align:center;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border)}.detail-header h3{margin:0 0 var(--space-1);font-size:var(--font-size-xl)}.detail-header p{margin:0;color:var(--color-text-tertiary)}.detail-summary{display:grid;grid-template-columns:repeat(5,1fr);gap:var(--space-2)}.summary-item{display:flex;flex-direction:column;align-items:center;padding:var(--space-2);background:var(--color-background-alt);border-radius:var(--radius-base)}.summary-item span{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:uppercase}.summary-item strong{font-size:var(--font-size-lg);color:var(--color-text-primary)}.result-breakdown{background:var(--color-surface);border-radius:var(--radius-base);padding:var(--space-3);border:1px solid var(--color-border-light)}.result-breakdown h4{margin:0 0 var(--space-2);font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-secondary)}.breakdown-row{display:flex;justify-content:space-between;padding:var(--space-1) 0;font-size:var(--font-size-sm);color:var(--color-text-secondary);border-bottom:1px dashed var(--color-border-light)}.breakdown-row:last-child{border-bottom:none}.breakdown-sub{padding-left:var(--space-3);font-size:var(--font-size-xs);color:var(--color-text-tertiary);background:var(--color-background-alt);margin:0 calc(var(--space-3) * -1);padding:var(--space-1) var(--space-3) var(--space-1) var(--space-6)}.breakdown-total{font-weight:var(--font-weight-semibold);color:var(--color-text-primary);padding-top:var(--space-2);margin-top:var(--space-1);border-top:2px solid var(--color-border);border-bottom:none}.breakdown-net{font-weight:var(--font-weight-bold);font-size:var(--font-size-lg);color:var(--color-primary);background:var(--color-primary-lighter);margin:var(--space-2) calc(var(--space-3) * -1) calc(var(--space-3) * -1);padding:var(--space-2) var(--space-3);border-radius:0 0 var(--radius-base) var(--radius-base);border-top:2px solid var(--color-primary)}.daily-breakdown{margin-top:var(--space-3);padding-top:var(--space-3);border-top:1px solid var(--color-border)}.daily-breakdown-header{display:flex;justify-content:space-between;align-items:center;cursor:pointer;padding:var(--space-2);background:var(--color-background-alt);border-radius:var(--radius-base);margin-bottom:var(--space-2)}.daily-breakdown-header:hover{background:var(--color-surface)}.daily-breakdown h4{margin:0;font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.daily-list{display:flex;flex-direction:column;gap:var(--space-2)}.daily-item{background:var(--color-surface);border:1px solid var(--color-border-light);border-radius:var(--radius-base);overflow:hidden}.daily-item-absent{border-color:var(--color-error-light);background:rgba(239,68,68,.05)}.daily-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-2);cursor:pointer;transition:background var(--transition-fast)}.daily-header:hover{background:var(--color-background-alt)}.daily-date{display:flex;flex-direction:column}.date-day{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.date-full{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.daily-info{display:flex;align-items:center;gap:var(--space-2)}.daily-hours{font-weight:var(--font-weight-semibold);color:var(--color-text-primary)}.daily-details{padding:var(--space-2);background:var(--color-background-alt);border-top:1px solid var(--color-border-light);font-size:var(--font-size-sm)}.daily-times,.daily-hours-breakdown{display:flex;gap:var(--space-3);margin-bottom:var(--space-1)}.time-entries{margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px dashed var(--color-border-light)}.time-entry{padding:var(--space-1) 0;color:var(--color-text-secondary)}@media(max-width:900px){.generate-inputs{grid-template-columns:1fr 1fr}.result-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:768px){.page-header{flex-direction:column;align-items:stretch;gap:var(--space-2)}.generate-inputs{grid-template-columns:1fr}.detail-summary{grid-template-columns:repeat(2,1fr)}.daily-times,.daily-hours-breakdown{flex-direction:column;gap:var(--space-1)}.daily-info{flex-wrap:wrap;gap:var(--space-1)}.table-actions{flex-direction:column;gap:var(--space-1)}}@media(max-width:480px){.page-title{font-size:var(--font-size-xl)}.result-grid{grid-template-columns:1fr}.result-header,.result-employee{flex-direction:column;text-align:center}.detail-summary{grid-template-columns:1fr}.breakdown-row{flex-direction:column;gap:var(--space-1);text-align:center}.employee-cell-info{display:none}.form-actions{flex-direction:column}.form-actions>*{width:100%}}.deductions-page{display:flex;flex-direction:column;gap:var(--space-4)}.page-header{display:flex;justify-content:space-between;align-items:flex-start}.deduction-form-card{display:flex;flex-direction:column;gap:var(--space-3)}.deduction-form-row{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3)}.deduction-form-row-3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-3)}.deduction-preview{background:var(--color-background-alt);padding:var(--space-2) var(--space-3);border-radius:var(--radius-base);font-size:var(--font-size-sm);color:var(--color-text-secondary);text-align:center;border:1px dashed var(--color-border)}.deduction-form-actions{display:flex;justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-light)}.react-select-container{font-size:var(--font-size-sm)}.select-label{display:block;font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);margin-bottom:var(--space-1)}.deductions-filters{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-3);margin-bottom:var(--space-3)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.edit-form{display:flex;flex-direction:column;gap:var(--space-3)}@media(max-width:768px){.deduction-form-row,.deduction-form-row-3,.deductions-filters{grid-template-columns:1fr}.page-header{flex-direction:column;gap:var(--space-2)}.deduction-form-actions{flex-direction:column}.deduction-form-actions>*{width:100%}}.roles-page{display:flex;flex-direction:column;gap:var(--space-4)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-2)}.loading-state,.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center;color:var(--color-text-tertiary)}.empty-state h3{margin:var(--space-2) 0 var(--space-1);color:var(--color-text-primary)}.empty-state p{margin:0 0 var(--space-3)}.roles-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:var(--space-3)}.role-card{display:flex;flex-direction:column;gap:var(--space-2)}.role-header{display:flex;justify-content:space-between;align-items:flex-start}.role-icon{width:48px;height:48px;background:var(--color-primary-lighter);color:var(--color-primary);border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center}.role-name{font-size:var(--font-size-lg);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.role-description{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:0;line-height:var(--line-height-relaxed)}.role-stats{display:flex;gap:var(--space-3);padding:var(--space-2);background:var(--color-background-alt);border-radius:var(--radius-base)}.role-stat{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.role-permissions-preview{display:flex;flex-wrap:wrap;gap:6px}.permission-tag{font-size:var(--font-size-xs);padding:2px 8px;background:var(--color-secondary);color:var(--color-text-secondary);border-radius:var(--radius-sm)}.permission-more{font-size:var(--font-size-xs);padding:2px 8px;color:var(--color-primary);font-weight:var(--font-weight-medium)}.role-actions{display:flex;gap:var(--space-2);margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-light);flex-wrap:wrap}.btn-danger-outline{color:var(--color-error);border-color:var(--color-error-light)}.btn-danger-outline:hover:not(:disabled){background:var(--color-error-light)}.role-form{display:flex;flex-direction:column;gap:var(--space-3)}.form-actions{display:flex;justify-content:flex-end;gap:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-light)}.permissions-modal{display:flex;flex-direction:column;gap:var(--space-3)}.permissions-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:var(--space-3);max-height:400px;overflow-y:auto;padding:var(--space-1)}.permission-category{background:var(--color-background-alt);border-radius:var(--radius-base);padding:var(--space-2)}.category-title{font-size:var(--font-size-sm);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0 0 var(--space-2);padding-bottom:var(--space-1);border-bottom:1px solid var(--color-border-light)}.permission-list{display:flex;flex-direction:column;gap:var(--space-1)}.permission-item{display:flex;align-items:center;gap:var(--space-1);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:background-color var(--transition-fast)}.permission-item:hover{background:var(--color-surface)}.permission-item input{display:none}.permission-checkbox{width:18px;height:18px;border:2px solid var(--color-border);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;flex-shrink:0;transition:all var(--transition-fast)}.permission-item input:checked+.permission-checkbox{background:var(--color-primary);border-color:var(--color-primary);color:#fff}.permission-label{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.delete-modal-content{text-align:center}.delete-modal-content p{margin:0 0 var(--space-2);color:var(--color-text-secondary)}.delete-warning{color:var(--color-error);font-size:var(--font-size-sm)}.delete-modal-content .form-actions{justify-content:center;margin-top:var(--space-3)}.monitor-page{display:flex;flex-direction:column;gap:var(--space-4)}.page-header{display:flex;justify-content:space-between;align-items:flex-start;flex-wrap:wrap;gap:var(--space-3)}.page-title{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary);margin:0}.page-subtitle{font-size:var(--font-size-sm);color:var(--color-text-tertiary);margin:var(--space-1) 0 0}.monitor-controls{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.auto-refresh-toggle{display:flex;align-items:center;gap:var(--space-1);font-size:var(--font-size-sm);color:var(--color-text-secondary);cursor:pointer}.auto-refresh-toggle input{cursor:pointer}.spinning{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.monitor-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--space-3)}.stat-card{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-4);background:var(--color-surface);border-radius:var(--radius-lg);border:1px solid var(--color-border-light);box-shadow:var(--shadow-sm)}.stat-icon{width:48px;height:48px;border-radius:var(--radius-base);display:flex;align-items:center;justify-content:center}.stat-online .stat-icon{background:rgba(34,197,94,.1);color:#22c55e}.stat-away .stat-icon{background:rgba(249,115,22,.1);color:#f97316}.stat-working .stat-icon{background:rgba(59,130,246,.1);color:#3b82f6}.stat-offline .stat-icon{background:rgba(107,114,128,.1);color:#6b7280}.stat-content{display:flex;flex-direction:column}.stat-value{font-size:var(--font-size-2xl);font-weight:var(--font-weight-bold);color:var(--color-text-primary)}.stat-label{font-size:var(--font-size-sm);color:var(--color-text-tertiary)}.monitor-tabs{display:flex;gap:var(--space-2);border-bottom:1px solid var(--color-border-light);padding-bottom:var(--space-2)}.monitor-tab{display:flex;align-items:center;gap:var(--space-1);padding:var(--space-2) var(--space-3);background:none;border:none;border-radius:var(--radius-base);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-secondary);cursor:pointer;transition:all var(--transition-fast)}.monitor-tab:hover{background:var(--color-background-alt);color:var(--color-text-primary)}.monitor-tab.active{background:var(--color-primary);color:#fff}.monitor-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.monitor-card{max-height:500px;display:flex;flex-direction:column;overflow:hidden}.monitor-card.all-users-card{overflow:hidden}.monitor-card.all-users-card .all-users-list{min-height:0;overflow-y:auto}.monitor-card.main-panel{grid-row:span 2}.card-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-3);border-bottom:1px solid var(--color-border-light);margin-bottom:var(--space-3)}.card-header h3{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-base);font-weight:var(--font-weight-semibold);color:var(--color-text-primary);margin:0}.header-note{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.users-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-2)}.user-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2) var(--space-3);background:var(--color-background-alt);border-radius:var(--radius-base);transition:all var(--transition-fast)}.user-item:hover{background:var(--color-border-light)}.user-avatar{position:relative;width:44px;height:44px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-avatar span{color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-lg)}.status-indicator{position:absolute;bottom:2px;right:2px;width:12px;height:12px;border-radius:50%;border:2px solid var(--color-surface)}.status-indicator.online{background:#22c55e}.status-indicator.working{background:#3b82f6}.user-info{flex:1;display:flex;flex-direction:column;gap:4px;min-width:0}.user-name{font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-details{display:flex;align-items:center;gap:var(--space-2);flex-wrap:wrap}.user-location,.check-in-time{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.user-activity{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.activity-device{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--color-text-secondary);padding:2px 8px;background:var(--color-border-light);border-radius:var(--radius-sm)}.activity-time{display:flex;flex-direction:column;align-items:flex-end}.time-formatted{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.time-ago{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.user-hours{display:flex;align-items:center;gap:4px;padding:var(--space-1) var(--space-2);background:var(--color-primary-lighter);color:var(--color-primary);border-radius:var(--radius-sm);font-size:var(--font-size-sm);font-weight:var(--font-weight-medium)}.all-users-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-1)}.all-user-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-base);transition:all var(--transition-fast)}.all-user-item:hover{background:var(--color-background-alt)}.all-user-item.offline{opacity:.6}.all-user-avatar{position:relative;width:32px;height:32px;border-radius:50%;background:var(--color-primary);display:flex;align-items:center;justify-content:center;overflow:hidden;flex-shrink:0}.all-user-avatar img{width:100%;height:100%;object-fit:cover}.all-user-avatar span{color:#fff;font-weight:var(--font-weight-semibold);font-size:var(--font-size-sm)}.status-dot{position:absolute;bottom:0;right:0;width:10px;height:10px;border-radius:50%;border:2px solid var(--color-surface)}.status-dot.online{background:#22c55e}.status-dot.away{background:#f97316}.status-dot.offline{background:#6b7280}.all-user-info{flex:1;display:flex;flex-direction:column;min-width:0}.all-user-name{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.all-user-role{font-size:var(--font-size-xs);color:var(--color-text-tertiary);text-transform:capitalize}.all-user-status{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.last-seen{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.activity-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:var(--space-1)}.activity-item{display:flex;align-items:center;gap:var(--space-2);padding:var(--space-2);border-radius:var(--radius-base);transition:all var(--transition-fast)}.activity-item:hover{background:var(--color-background-alt)}.activity-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;flex-shrink:0}.activity-icon.check_in{background:rgba(34,197,94,.1);color:#22c55e}.activity-icon.check_out{background:rgba(239,68,68,.1);color:#ef4444}.activity-content{flex:1;display:flex;flex-direction:column;min-width:0}.activity-user{font-weight:var(--font-weight-medium);color:var(--color-text-primary);font-size:var(--font-size-sm)}.activity-action{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.activity-time{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.activity-time-formatted{font-size:var(--font-size-sm);font-weight:var(--font-weight-medium);color:var(--color-text-primary)}.activity-time-ago{font-size:var(--font-size-xs);color:var(--color-text-tertiary)}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-6);color:var(--color-text-tertiary);text-align:center}.empty-state svg{margin-bottom:var(--space-2);opacity:.5}.empty-state p{margin:0;font-size:var(--font-size-sm)}.force-checkout-content{text-align:center}.force-checkout-content p{margin:0 0 var(--space-2);color:var(--color-text-secondary)}.force-checkout-warning{color:var(--color-error);font-size:var(--font-size-sm)}.force-checkout-content .form-actions{display:flex;justify-content:center;gap:var(--space-2);margin-top:var(--space-4)}@media(max-width:1200px){.monitor-stats{grid-template-columns:repeat(2,1fr)}.monitor-grid{grid-template-columns:1fr}.monitor-card.main-panel{grid-row:auto}}@media(max-width:768px){.page-header,.monitor-controls{flex-direction:column;align-items:stretch}.monitor-stats{grid-template-columns:repeat(2,1fr)}.stat-card{padding:var(--space-3)}.stat-value{font-size:var(--font-size-xl)}.monitor-tabs{overflow-x:auto}.user-item{flex-wrap:wrap}.user-activity{order:3;width:100%;flex-direction:row;justify-content:space-between;margin-top:var(--space-2);padding-top:var(--space-2);border-top:1px solid var(--color-border-light)}}@media(max-width:480px){.monitor-stats{grid-template-columns:1fr}}.users-list,.all-users-list,.activity-list{scrollbar-width:thin;scrollbar-color:var(--color-border) var(--color-background-alt)}.users-list::-webkit-scrollbar,.all-users-list::-webkit-scrollbar,.activity-list::-webkit-scrollbar{width:8px}.users-list::-webkit-scrollbar-track,.all-users-list::-webkit-scrollbar-track,.activity-list::-webkit-scrollbar-track{background:var(--color-background-alt);border-radius:var(--radius-base)}.users-list::-webkit-scrollbar-thumb,.all-users-list::-webkit-scrollbar-thumb,.activity-list::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:var(--radius-base);border:2px solid var(--color-background-alt)}.users-list::-webkit-scrollbar-thumb:hover,.all-users-list::-webkit-scrollbar-thumb:hover,.activity-list::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}.badges-page{padding:24px}.badges-header{margin-bottom:24px}.badges-title{display:flex;align-items:center;gap:12px;margin-bottom:8px}.badges-title h1{font-size:24px;font-weight:700;margin:0;color:var(--color-text)}.badges-title svg{color:var(--color-primary)}.badges-subtitle{color:var(--color-text-muted);font-size:14px;margin:0}.badges-card{padding:20px}.badges-toolbar{margin-bottom:20px}.search-box{display:flex;align-items:center;gap:8px;max-width:320px}.search-box svg{color:var(--color-text-muted)}.badges-loading{text-align:center;padding:40px;color:var(--color-text-muted)}.badges-empty{text-align:center;padding:60px 20px;color:var(--color-text-muted)}.badges-empty svg{margin-bottom:16px;opacity:.5}.badges-empty p{font-size:16px;font-weight:600;margin:0 0 4px}.badges-empty span{font-size:14px}.badges-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:20px}.badge-item{background:var(--color-bg);border:1px solid var(--color-border);padding:16px;display:flex;flex-direction:column;gap:12px}.badge-preview{width:80px;height:80px;background:#f3f4f6;overflow:hidden;display:flex;align-items:center;justify-content:center;margin:0 auto}.badge-preview img{width:100%;height:100%;object-fit:cover}.badge-placeholder{color:#9ca3af}.badge-details{text-align:center}.badge-details h3{font-size:16px;font-weight:600;margin:0 0 4px;color:var(--color-text)}.badge-position{font-size:13px;color:var(--color-text-muted);margin:0 0 4px}.badge-code{font-size:12px;font-family:monospace;color:var(--color-primary);font-weight:600;margin:0 0 12px}.badge-meta{display:flex;justify-content:center;gap:16px;font-size:12px;color:var(--color-text-muted);margin-bottom:8px}.badge-type,.badge-location{display:flex;align-items:center;gap:4px}.badge-footer{display:flex;justify-content:center;gap:8px;font-size:11px;color:var(--color-text-muted)}.badge-date{display:flex;align-items:center;gap:4px}.badge-actions{display:flex;gap:8px;justify-content:center;margin-top:8px}.delete-modal-content{padding:20px 0}.delete-modal-content p{margin:0 0 8px;color:var(--color-text)}.delete-warning{font-size:13px;color:var(--color-text-muted)}.delete-modal-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:24px}.terminal-page{min-height:100vh;height:100vh;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#1a1a1a;color:#f5f1e8;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;padding:0;user-select:none;overflow:hidden;position:relative}.terminal-fullscreen-btn{background:none;border:1px solid #3A3A3A;color:#a0a0a0;padding:.4rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;transition:all .2s}.terminal-fullscreen-btn:hover{border-color:#d84040;color:#d84040}.terminal-bottom-bar{position:fixed;bottom:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem}.terminal-header-actions{display:flex;align-items:center;gap:.5rem}.terminal-clock{text-align:center;margin-bottom:2rem}.terminal-time{font-size:3.5rem;font-weight:700;font-family:monospace;letter-spacing:4px;color:#fff}.terminal-date{font-size:1.1rem;color:#a0a0a0;margin-top:.5rem}.terminal-pin-card{background:#242424;border:1px solid #3A3A3A;border-radius:8px;padding:2.5rem;text-align:center;width:90%;max-width:380px}.pin-icon{color:#d84040;margin-bottom:1rem}.terminal-pin-card h2{margin:0 0 .5rem;font-size:1.4rem;font-weight:700;color:#fff}.terminal-pin-card p{margin:0 0 1.5rem;color:#a0a0a0;font-size:.95rem}.pin-form{display:flex;flex-direction:column;gap:1rem}.pin-input{width:100%;padding:.85rem;font-size:1.4rem;text-align:center;letter-spacing:8px;background:#1a1a1a;border:2px solid #3A3A3A;border-radius:6px;color:#fff;outline:none;transition:border-color .2s;box-sizing:border-box}.pin-input:focus{border-color:#d84040}.pin-submit{padding:.85rem;font-size:1.05rem;font-weight:600;background:#d84040;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.pin-submit:hover:not(:disabled){background:#b83333}.pin-submit:disabled{opacity:.5;cursor:not-allowed}.pin-error{display:flex;align-items:center;justify-content:center;gap:.5rem;margin-top:1rem;color:#e66060;font-size:.9rem}.terminal-brand{color:#4a4a4a;font-size:.8rem;letter-spacing:2px;text-transform:uppercase}.terminal-header{position:fixed;top:0;left:0;right:0;display:flex;align-items:center;justify-content:space-between;padding:.6rem 1.5rem;background:#242424;border-bottom:1px solid #3A3A3A;z-index:10}.terminal-clock-small{display:flex;align-items:center;gap:.5rem;font-family:monospace;font-size:1rem;color:#d0d0d0}.terminal-header-title{font-size:.9rem;font-weight:600;color:#d84040;letter-spacing:1px;text-transform:uppercase}.terminal-lock-btn{background:none;border:1px solid #3A3A3A;color:#a0a0a0;padding:.4rem;border-radius:4px;cursor:pointer;display:flex;align-items:center;transition:all .2s}.terminal-lock-btn:hover{border-color:#d84040;color:#d84040}.terminal-body{flex:1;display:flex;align-items:center;justify-content:center;width:100%;max-width:600px;padding:50px 1.5rem 0;box-sizing:border-box}.terminal-scan-area{text-align:center;width:100%}.terminal-scan-icon{color:#d84040;margin-bottom:1.5rem;opacity:.8}.terminal-scan-area h2{margin:0 0 .4rem;font-size:1.75rem;font-weight:700;color:#fff}.terminal-scan-area p{margin:0;font-size:1rem;color:#7a7a7a}.terminal-loading{display:flex;align-items:center;justify-content:center;gap:1rem;margin-top:1.5rem;color:#a0a0a0;font-size:1rem}.terminal-spinner{width:22px;height:22px;border:3px solid #3A3A3A;border-top:3px solid #D84040;border-radius:50%;animation:spin .8s linear infinite}.terminal-result{text-align:center;width:100%;border-radius:8px;overflow:hidden}.terminal-result-banner{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1rem;font-size:1.5rem;font-weight:800;letter-spacing:3px;text-transform:uppercase}.banner-checkin{background:#2d7d4f;color:#fff}.banner-checkout{background:#e8991c;color:#fff}.terminal-result-employee{background:#242424;padding:1.5rem;display:flex;flex-direction:column;align-items:center}.terminal-result-info{text-align:center}.terminal-avatar{width:80px;height:80px;border-radius:50%;background:#d84040;display:flex;align-items:center;justify-content:center;overflow:hidden;margin-bottom:1rem;border:3px solid #3A3A3A;flex-shrink:0}.terminal-avatar img{width:100%;height:100%;object-fit:cover}.terminal-avatar span{font-size:2rem;font-weight:700;color:#fff}.terminal-result-employee h1{margin:0 0 .25rem;font-size:1.6rem;font-weight:700;color:#fff}.terminal-emp-code{margin:0;font-family:monospace;font-size:.9rem;color:#7a7a7a}.terminal-emp-location{margin:.3rem 0 0;font-size:.85rem;color:#a0a0a0}.terminal-result-time{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem;background:#2a2a2a;font-size:1.1rem;font-weight:600;color:#d0d0d0;font-family:monospace}.terminal-result-hint{display:flex;align-items:center;justify-content:center;gap:.5rem;padding:.6rem;background:#242424;font-size:.8rem;color:#4a4a4a}.terminal-error{text-align:center;width:100%;padding:2rem}.terminal-error svg{color:#e66060;margin-bottom:.75rem}.terminal-error h2{margin:0 0 1rem;font-size:1.3rem;color:#e66060}.terminal-retry-btn{padding:.6rem 1.5rem;font-size:.95rem;font-weight:600;background:#3a3a3a;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:background .2s}.terminal-retry-btn:hover{background:#4a4a4a}@media(orientation:landscape){.terminal-page{padding:0}.terminal-clock{margin-bottom:1rem}.terminal-time{font-size:2.5rem}.terminal-date{font-size:.9rem}.terminal-pin-card{padding:1.5rem 2rem}.terminal-pin-card h2{font-size:1.2rem}.terminal-pin-card p{margin-bottom:1rem;font-size:.85rem}.pin-input{padding:.6rem;font-size:1.2rem}.pin-submit{padding:.6rem;font-size:.95rem}.pin-icon{margin-bottom:.5rem}.pin-icon svg{width:32px;height:32px}.terminal-header{padding:.4rem 1.5rem}.terminal-body{padding-top:40px}.terminal-scan-icon{margin-bottom:.75rem}.terminal-scan-icon svg{width:48px!important;height:48px!important}.terminal-scan-area h2{font-size:1.4rem}.terminal-scan-area p{font-size:.9rem}.terminal-result-banner{padding:.7rem;font-size:1.2rem;gap:.5rem}.terminal-result-banner svg{width:24px;height:24px}.terminal-result-employee{flex-direction:row;padding:1rem 1.5rem;gap:1.25rem;text-align:left}.terminal-result-info{text-align:left}.terminal-avatar{width:64px;height:64px;margin-bottom:0}.terminal-avatar span{font-size:1.5rem}.terminal-result-employee h1{font-size:1.3rem}.terminal-emp-code{font-size:.8rem}.terminal-result-time{padding:.5rem;font-size:.95rem}.terminal-result-hint{padding:.4rem;font-size:.75rem}.terminal-error{padding:1rem}.terminal-error svg{width:28px;height:28px}.terminal-error h2{font-size:1.1rem;margin-bottom:.75rem}.terminal-brand{bottom:.5rem;font-size:.7rem}}@media(orientation:landscape)and (max-height:500px){.terminal-clock{margin-bottom:.5rem}.terminal-time{font-size:2rem}.terminal-date{font-size:.8rem;margin-top:.25rem}.terminal-pin-card{padding:1rem 1.5rem}.terminal-pin-card h2{font-size:1rem;margin-bottom:.25rem}.terminal-pin-card p{margin-bottom:.75rem;font-size:.8rem}.pin-icon{margin-bottom:.4rem}.pin-icon svg{width:24px;height:24px}.pin-form{gap:.5rem}.pin-input{padding:.5rem;font-size:1rem}.pin-submit{padding:.5rem;font-size:.85rem}.terminal-header{padding:.3rem 1rem}.terminal-clock-small{font-size:.85rem}.terminal-header-title{font-size:.75rem}.terminal-body{padding-top:35px}.terminal-scan-icon{margin-bottom:.5rem}.terminal-scan-icon svg{width:36px!important;height:36px!important}.terminal-scan-area h2{font-size:1.2rem}.terminal-scan-area p{font-size:.8rem}.terminal-result-banner{padding:.5rem;font-size:1rem}.terminal-result-employee{padding:.75rem 1rem;gap:1rem}.terminal-avatar{width:50px;height:50px}.terminal-avatar span{font-size:1.25rem}.terminal-result-employee h1{font-size:1.1rem}.terminal-result-time{padding:.35rem;font-size:.85rem}.terminal-result-hint{padding:.3rem;font-size:.7rem}}@media(orientation:portrait)and (max-width:480px){.terminal-page{padding:1rem}.terminal-time{font-size:2.5rem}.terminal-pin-card{padding:1.5rem}.terminal-scan-area h2{font-size:1.5rem}.terminal-result-banner{font-size:1.25rem}.terminal-result-employee h1{font-size:1.4rem}.terminal-avatar{width:70px;height:70px}}:root{--color-primary: #D84040;--color-primary-dark: #B83333;--color-primary-light: #E66060;--color-primary-lighter: #F9E5E5;--color-secondary: #F5F1E8;--color-secondary-dark: #E8E4DB;--color-secondary-darker: #D4D0C7;--color-background: #FFFFFF;--color-background-alt: #FAFAF9;--color-background-dark: #F5F1E8;--color-surface: #FFFFFF;--color-surface-hover: #FAFAF9;--color-text-primary: #1A1A1A;--color-text-secondary: #4A4A4A;--color-text-tertiary: #7A7A7A;--color-text-on-primary: #FFFFFF;--color-border: #E5E5E5;--color-border-light: #F0F0F0;--color-border-dark: #D0D0D0;--color-success: #2D7D4F;--color-success-light: #E8F5EE;--color-warning: #E8991C;--color-warning-light: #FFF4E6;--color-error: #C73333;--color-error-light: #FFE8E8;--color-info: #2D6DB5;--color-info-light: #E8F1FA;--sidebar-width: 260px;--sidebar-collapsed-width: 70px;--sidebar-bg: var(--color-surface);--sidebar-border: var(--color-border);--sidebar-item-hover: var(--color-primary-lighter);--sidebar-item-active: var(--color-primary);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 1.875rem;--font-weight-normal: 400;--font-weight-medium: 500;--font-weight-semibold: 600;--font-weight-bold: 700;--line-height-tight: 1.25;--line-height-normal: 1.5;--line-height-relaxed: 1.75;--space-1: .5rem;--space-2: 1rem;--space-3: 1.5rem;--space-4: 2rem;--space-5: 2.5rem;--space-6: 3rem;--space-8: 4rem;--space-10: 5rem;--radius-none: 0;--radius-sm: 2px;--radius-base: 4px;--radius-md: 4px;--radius-lg: 4px;--shadow-xs: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-sm: 0 1px 3px 0 rgba(0, 0, 0, .08);--shadow-base: 0 2px 6px 0 rgba(0, 0, 0, .1);--shadow-md: 0 4px 12px 0 rgba(0, 0, 0, .12);--shadow-lg: 0 8px 24px 0 rgba(0, 0, 0, .15);--shadow-xl: 0 16px 48px 0 rgba(0, 0, 0, .18);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--z-dropdown: 1000;--z-sticky: 1020;--z-fixed: 1030;--z-modal-backdrop: 1040;--z-modal: 1050;--z-popover: 1060;--z-tooltip: 1070}[data-theme=dark]{--color-background: #1A1A1A;--color-background-alt: #242424;--color-background-dark: #2A2A2A;--color-surface: #242424;--color-surface-hover: #2A2A2A;--color-text-primary: #F5F1E8;--color-text-secondary: #D0D0D0;--color-text-tertiary: #A0A0A0;--color-border: #3A3A3A;--color-border-light: #2A2A2A;--color-border-dark: #4A4A4A}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility;font-size:16px}body{font-family:var(--font-family);font-size:var(--font-size-base);font-weight:var(--font-weight-normal);line-height:var(--line-height-normal);color:var(--color-text-primary);background-color:var(--color-background);overflow-x:hidden;min-height:100vh}#root{min-height:100vh;width:100%;overflow-x:hidden}html{overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--color-background-alt)}::-webkit-scrollbar-thumb{background:var(--color-border-dark);border-radius:var(--radius-base)}::-webkit-scrollbar-thumb:hover{background:var(--color-text-tertiary)}h1,h2,h3,h4,h5,h6{font-weight:var(--font-weight-semibold);line-height:var(--line-height-tight);color:var(--color-text-primary)}h1{font-size:var(--font-size-3xl)}h2{font-size:var(--font-size-2xl)}h3{font-size:var(--font-size-xl)}h4{font-size:var(--font-size-lg)}h5{font-size:var(--font-size-base)}h6{font-size:var(--font-size-sm)}p{margin-bottom:var(--space-2)}a{color:var(--color-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--color-primary-dark)}button,input,optgroup,select,textarea{font-family:inherit;font-size:inherit;line-height:inherit;margin:0}button{cursor:pointer;background:none;border:none;outline:none}input,textarea,select{outline:none}ul,ol{list-style:none}img{max-width:100%;height:auto;display:block}table{border-collapse:collapse;width:100%}.container{width:100%;max-width:1400px;margin:0 auto;padding:0 var(--space-3)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.font-bold{font-weight:var(--font-weight-bold)}.font-semibold{font-weight:var(--font-weight-semibold)}.font-medium{font-weight:var(--font-weight-medium)}.text-xs{font-size:var(--font-size-xs)}.text-sm{font-size:var(--font-size-sm)}.text-base{font-size:var(--font-size-base)}.text-lg{font-size:var(--font-size-lg)}.text-xl{font-size:var(--font-size-xl)}.text-primary{color:var(--color-text-primary)}.text-secondary{color:var(--color-text-secondary)}.text-tertiary{color:var(--color-text-tertiary)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.fade-in{animation:fadeIn var(--transition-base)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.slide-in-right{animation:slideInRight var(--transition-base)}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.slide-in-left{animation:slideInLeft var(--transition-base)}@keyframes slideInLeft{0%{opacity:0;transform:translate(-20px)}to{opacity:1;transform:translate(0)}}.badge{display:inline-flex;align-items:center;padding:4px 12px;border-radius:var(--radius-base);font-size:var(--font-size-xs);font-weight:var(--font-weight-medium);text-transform:uppercase;letter-spacing:.5px}.badge-success{background-color:var(--color-success-light);color:var(--color-success)}.badge-warning{background-color:var(--color-warning-light);color:var(--color-warning)}.badge-error{background-color:var(--color-error-light);color:var(--color-error)}.badge-info{background-color:var(--color-info-light);color:var(--color-info)}.badge-primary{background-color:var(--color-primary-lighter);color:var(--color-primary)}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.card{background:var(--color-surface);border:1px solid var(--color-border);border-radius:var(--radius-base);padding:var(--space-3);box-shadow:var(--shadow-sm);transition:box-shadow var(--transition-fast)}.card:hover{box-shadow:var(--shadow-md)}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:var(--color-background);gap:var(--space-3)}.loading-spinner{width:48px;height:48px;border:3px solid var(--color-border);border-top-color:var(--color-primary);border-radius:50%;animation:spin .8s linear infinite}.loading-screen p{color:var(--color-text-tertiary);font-size:var(--font-size-sm)}
