@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;inset:0;background-color:#00000080;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;-webkit-user-select:none;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;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;inset: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;inset: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;inset: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;-webkit-user-select:none;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;inset:0;display:flex;align-items:center;justify-content:center;z-index:var(--z-modal);padding:var(--space-2)}.modal-overlay{position:fixed;inset:0;background-color:#00000080;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;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)}.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}.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;inset:0;background:#0009;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%}}.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{display:flex;justify-content:space-between;align-items:flex-start}.calculator-form{display:flex;flex-direction:column;gap:var(--space-4)}.calculator-inputs{display:grid;grid-template-columns:2fr 1fr 1fr auto;gap:var(--space-3);align-items:end}@media(max-width:900px){.calculator-inputs{grid-template-columns:1fr 1fr}.calculator-inputs>*:first-child{grid-column:1 / -1}}@media(max-width:600px){.calculator-inputs{grid-template-columns:1fr}}.calculator-actions{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)}.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)}@media(max-width:800px){.result-grid{grid-template-columns:repeat(2,1fr)}}@media(max-width:500px){.result-grid{grid-template-columns:1fr}}.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)}.result-item-highlight{background:var(--color-primary-lighter);border-color:var(--color-primary)}.result-item-highlight svg{color:var(--color-primary)}.result-value-large{font-size:var(--font-size-xl);color:var(--color-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)}.sunday-breakdown{margin:0}.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)}.text-success{color:var(--color-success)}.text-error{color:var(--color-error)}.text-warning{color:var(--color-warning)}.bulk-generate{display:flex;flex-direction:column;gap:var(--space-3)}.bulk-inputs{display:grid;grid-template-columns:1fr 1fr 1fr;gap:var(--space-3)}@media(max-width:768px){.bulk-inputs{grid-template-columns:1fr}}.settings-form{display:flex;flex-direction:column;gap:var(--space-3)}.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:#ef44440d}.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)}.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)}.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)}@media(max-width:768px){.detail-summary{grid-template-columns:repeat(2,1fr)}}.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)}@media(max-width:768px){.page-header{flex-direction:column;align-items:stretch;gap:var(--space-2)}.calculator-inputs{grid-template-columns:1fr}.result-header,.result-employee{flex-direction:column;text-align:center}.result-grid{grid-template-columns:1fr 1fr}.bulk-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,.detail-summary{grid-template-columns:1fr}.result-item{padding:var(--space-1)}.result-value{font-size:var(--font-size-base)}.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%}}.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:#22c55e1a;color:#22c55e}.stat-away .stat-icon{background:#f973161a;color:#f97316}.stat-working .stat-icon{background:#3b82f61a;color:#3b82f6}.stat-offline .stat-icon{background:#6b72801a;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:#22c55e1a;color:#22c55e}.activity-icon.check_out{background:#ef44441a;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)}: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)}
