:root{--primary:#bcf000;--primary-hover:#a8d600;--primary-light:#d4f54e;--secondary:#6b7280;--accent:#374151;--success:#10b981;--success-light:#d1fae5;--warning:#f59e0b;--warning-light:#fef3c7;--danger:#ef4444;--danger-light:#fee2e2;--info:#3b82f6;--info-light:#dbeafe;--gray-50:#f9fafb;--gray-100:#f3f4f6;--gray-200:#e5e7eb;--gray-300:#d1d5db;--gray-400:#9ca3af;--gray-500:#6b7280;--gray-600:#4b5563;--gray-700:#374151;--gray-800:#1f2937;--gray-900:#111827;--sidebar-width:260px;--header-height:70px;--shadow-sm:0 1px 2px 0 #0000000d;--shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;--shadow-md:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -2px #0000000d;--shadow-xl:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;--radius-sm:0.375rem;--radius:0.5rem;--radius-lg:0.75rem;--radius-xl:1rem;--transition:all 0.2s ease}*{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f9fafb;background-color:var(--gray-50);color:#111827;color:var(--gray-900);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;line-height:1.6}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}::-webkit-scrollbar{height:8px;width:8px}::-webkit-scrollbar-track{background:#f3f4f6;background:var(--gray-100)}::-webkit-scrollbar-thumb{background:#d1d5db;background:var(--gray-300);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--gray-400)}.btn{align-items:center;border:none;border-radius:.5rem;border-radius:var(--radius);cursor:pointer;display:inline-flex;font-size:.875rem;font-weight:500;gap:.5rem;padding:.625rem 1.25rem;text-decoration:none;transition:all .2s ease;transition:var(--transition);white-space:nowrap}.btn:disabled{cursor:not-allowed;opacity:.5}.btn-primary{background:#bcf000;background:var(--primary);color:#fff}.btn-primary:hover:not(:disabled){background:#a8d600;background:var(--primary-hover);box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md);transform:translateY(-1px)}.btn-secondary{background:#e5e7eb;background:var(--gray-200);color:#374151;color:var(--gray-700)}.btn-secondary:hover:not(:disabled){background:#d1d5db;background:var(--gray-300)}.btn-success{background:#10b981;background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#059669}.btn-danger{background:#ef4444;background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:#dc2626}.btn-sm{font-size:.8125rem;padding:.375rem .875rem}.btn-lg{font-size:1rem;padding:.75rem 1.5rem}.card{background:#fff;border-radius:.75rem;border-radius:var(--radius-lg);box-shadow:0 1px 3px 0 #0000001a,0 1px 2px 0 #0000000f;box-shadow:var(--shadow);overflow:hidden;transition:all .2s ease;transition:var(--transition)}.card:hover{box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;box-shadow:var(--shadow-md)}.card-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:1.25rem 1.5rem}.card-title{color:#111827;color:var(--gray-900);font-size:1.125rem;font-weight:600}.card-body{padding:1.5rem}.form-group{margin-bottom:1.25rem}.form-label{color:#374151;color:var(--gray-700);display:block;font-size:.875rem;font-weight:500;margin-bottom:.5rem}.form-input,.form-select,.form-textarea{background:#fff;border:1px solid #d1d5db;border:1px solid var(--gray-300);border-radius:.5rem;border-radius:var(--radius);font-size:.875rem;padding:.625rem .875rem;transition:all .2s ease;transition:var(--transition);width:100%}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:#9ca3af;border-color:var(--gray-400);box-shadow:0 0 0 3px #6b72801a;outline:none}.form-textarea{min-height:100px;resize:vertical}.form-error{color:#ef4444;color:var(--danger);font-size:.8125rem;margin-top:.375rem}.badge{align-items:center;border-radius:9999px;display:inline-flex;font-size:.75rem;font-weight:500;padding:.25rem .625rem;white-space:nowrap}.badge-success{background:#d1fae5;background:var(--success-light);color:#065f46}.badge-warning{background:#fef3c7;background:var(--warning-light);color:#92400e}.badge-danger{background:#fee2e2;background:var(--danger-light);color:#991b1b}.badge-info{background:#dbeafe;background:var(--info-light);color:#1e40af}.badge-gray{background:#e5e7eb;background:var(--gray-200);color:#374151;color:var(--gray-700)}.table-container{border:1px solid #e5e7eb;border:1px solid var(--gray-200);border-radius:.75rem;border-radius:var(--radius-lg);overflow-x:auto}.table{background:#fff;border-collapse:collapse;width:100%}.table thead{background:#f9fafb;background:var(--gray-50);border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200)}.table th{color:#4b5563;color:var(--gray-600);font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.875rem 1rem;text-align:left;text-transform:uppercase}.table td{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);font-size:.875rem;padding:1rem}.table tbody tr:hover{background:#f9fafb;background:var(--gray-50)}.modal-overlay{align-items:center;animation:fadeIn .2s ease;background:#00000080;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:1000}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.modal{animation:slideUp .3s ease;background:#fff;border-radius:1rem;border-radius:var(--radius-xl);box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;box-shadow:var(--shadow-xl);max-height:90vh;max-width:500px;overflow-y:auto;width:90%}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.modal-header{align-items:center;border-bottom:1px solid #e5e7eb;border-bottom:1px solid var(--gray-200);display:flex;justify-content:space-between;padding:1.5rem}.modal-title{color:#111827;color:var(--gray-900);font-size:1.25rem;font-weight:600}.modal-close{align-items:center;background:none;border:none;border-radius:.5rem;border-radius:var(--radius);color:#9ca3af;color:var(--gray-400);cursor:pointer;display:flex;font-size:1.5rem;height:2rem;justify-content:center;padding:0;transition:all .2s ease;transition:var(--transition);width:2rem}.modal-close:hover{background:#f3f4f6;background:var(--gray-100);color:#4b5563;color:var(--gray-600)}.modal-body,.modal-footer{padding:1.5rem}.modal-footer{border-top:1px solid #e5e7eb;border-top:1px solid var(--gray-200);display:flex;gap:.75rem;justify-content:flex-end}.text-center{text-align:center}.text-right{text-align:right}.d-flex{display:flex}.align-items-center{align-items:center}.justify-content-between{justify-content:space-between}.gap-1{gap:.5rem}.gap-2{gap:1rem}.gap-3{gap:1.5rem}.mb-1{margin-bottom:.5rem}.mb-2{margin-bottom:1rem}.mb-3{margin-bottom:1.5rem}.mb-4{margin-bottom:2rem}.mt-1{margin-top:.5rem}.mt-2{margin-top:1rem}.mt-3{margin-top:1.5rem}.mt-4{margin-top:2rem}.ml-auto{margin-left:auto}.loader{animation:spin 1s linear infinite;border:3px solid #e5e7eb;border-top:3px solid #4b5563;border:3px solid var(--gray-200);border-radius:50%;border-top-color:var(--gray-600);height:40px;width:40px}@keyframes spin{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}.loader-container{min-height:300px}.loader-container,.login-page{align-items:center;display:flex;justify-content:center}.login-page{background:linear-gradient(135deg,var(--gray-700) 0,var(--gray-900) 100%);min-height:100vh;padding:2rem}.login-container{max-width:450px;width:100%}.login-card{background:#fff;border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);overflow:hidden}.login-header{background:var(--gray-50);padding:2.5rem 2rem 1.5rem;text-align:center}.login-logo{align-items:center;display:flex;justify-content:center;margin-bottom:1.5rem}.login-logo-image{display:block;height:auto;object-fit:contain;width:140px}.login-title{color:var(--gray-900);font-size:1.75rem;font-weight:700;margin-bottom:.5rem}.login-subtitle{color:var(--gray-600);font-size:.9375rem}.login-form{padding:2rem}.login-error{align-items:center;background:var(--danger-light);border-radius:var(--radius);color:var(--danger);display:flex;font-size:.875rem;gap:.5rem;margin-bottom:1.5rem;padding:.875rem 1rem}.w-full{width:100%}.login-footer{background:var(--gray-50);border-top:1px solid var(--gray-200);padding:1.5rem 2rem 2rem}.demo-credentials{text-align:center}.demo-title{color:var(--gray-700);font-size:.8125rem;font-weight:600;margin-bottom:.75rem}.demo-items{display:flex;flex-direction:column;gap:.5rem}.demo-item{background:#fff;border-radius:var(--radius-sm);color:var(--gray-600);font-size:.8125rem;padding:.5rem}.demo-item strong{color:var(--gray-800);margin-right:.375rem}.dashboard{animation:fadeIn .3s ease}.stats-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));margin-bottom:2rem}.stat-card{align-items:center;background:#fff;border-left:4px solid;border-radius:var(--radius-lg);box-shadow:var(--shadow);display:flex;gap:1.25rem;padding:1.5rem;transition:var(--transition)}.stat-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-4px)}.stat-card-blue{border-color:#3b82f6}.stat-card-green{border-color:var(--success)}.stat-card-purple{border-color:var(--gray-500)}.stat-card-indigo{border-color:var(--gray-600)}.stat-card-orange{border-color:var(--warning)}.stat-card-pink{border-color:var(--gray-500)}.stat-icon{align-items:center;background:var(--gray-50);border-radius:var(--radius-lg);display:flex;flex-shrink:0;font-size:2.5rem;height:4rem;justify-content:center;width:4rem}.stat-content{flex:1 1}.stat-label{color:var(--gray-600);font-size:.875rem;font-weight:500;margin-bottom:.25rem}.stat-value{color:var(--gray-900);font-size:2rem;font-weight:700}.dashboard-section{margin-bottom:2rem}.section-title{color:var(--gray-900);font-size:1.25rem;font-weight:600;margin-bottom:1rem}.activities-list{display:flex;flex-direction:column;gap:1rem}.activity-item{align-items:center;background:var(--gray-50);border-radius:var(--radius);display:flex;gap:1rem;padding:1rem;transition:var(--transition)}.activity-item:hover{background:var(--gray-100)}.activity-icon{align-items:center;background:#fff;border-radius:var(--radius);display:flex;flex-shrink:0;font-size:1.5rem;height:2.5rem;justify-content:center;width:2.5rem}.activity-content{flex:1 1}.activity-user{color:var(--gray-900);font-weight:600;margin-bottom:.125rem}.activity-description{color:var(--gray-600);font-size:.875rem}.activity-date{color:var(--gray-500);font-size:.8125rem}.today-attendance{padding:1rem}.attendance-status{margin-bottom:1rem;text-align:center}.attendance-details{display:flex;gap:2rem;justify-content:center}.attendance-detail-item{display:flex;flex-direction:column;gap:.25rem}.detail-label{color:var(--gray-600);font-size:.8125rem;font-weight:500}.detail-value{color:var(--gray-900);font-size:1.125rem;font-weight:600}.main-layout{display:flex;min-height:100vh}.main-content{flex:1 1;margin-left:var(--sidebar-width);padding-top:var(--header-height)}.page-content{max-width:1600px;padding:2rem}.sidebar{background:#101010;bottom:0;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;left:0;position:fixed;top:0;width:var(--sidebar-width);z-index:100}.sidebar-header{border-bottom:1px solid #5454544d;padding:2rem 1.5rem}.logo-link,.sidebar-header{align-items:center;display:flex;justify-content:center}.logo-link{text-decoration:none;transition:var(--transition);width:100%}.logo-link:hover{opacity:.9;transform:scale(1.05)}.logo-image{display:block;height:auto;max-width:160px;object-fit:contain;width:80%}.sidebar-nav{flex:1 1;overflow-y:auto;padding:1.5rem 1rem}.sidebar-link{align-items:center;border-radius:var(--radius-lg);color:#fff;display:flex;font-size:.9375rem;font-weight:500;gap:.875rem;margin-bottom:.5rem;padding:.875rem 1rem;text-decoration:none;transition:var(--transition)}.sidebar-link:hover{background:#54545433;color:#fff;transform:translateX(4px)}.sidebar-link.active{background:var(--primary);box-shadow:0 4px 12px rgba(19,237,12,.862);color:#000;font-weight:600}.sidebar-icon{font-size:1.25rem;text-align:center;width:1.5rem}.sidebar-label{flex:1 1}.sidebar-footer{border-top:1px solid #5454544d;padding:1rem}.user-info{background:#54545426;border-radius:var(--radius-lg);gap:.875rem;padding:.75rem}.user-avatar,.user-info{align-items:center;display:flex}.user-avatar{background:var(--gray-600);border-radius:50%;color:#fff;flex-shrink:0;font-size:1rem;font-weight:600;height:2.5rem;justify-content:center;width:2.5rem}.user-details{flex:1 1;min-width:0}.user-name{color:#fff;font-size:.875rem;font-weight:500;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.user-role{color:#eee8e800;font-size:.75rem;text-transform:capitalize}.header{background:#fff;border-bottom:1px solid var(--gray-200);box-shadow:var(--shadow-sm);height:var(--header-height);left:var(--sidebar-width);position:fixed;right:0;top:0;z-index:90}.header-content{align-items:center;display:flex;height:100%;justify-content:space-between;padding:0 2rem}.header-title{color:var(--gray-900);font-size:1.5rem;font-weight:700;margin:0}.header-actions{align-items:center;display:flex;gap:1rem}.employees-page{animation:fadeIn .3s ease}.page-header{align-items:center;display:flex;flex-wrap:wrap;gap:1.5rem;justify-content:space-between;margin-bottom:1.5rem}.page-filters{display:flex;flex:1 1;flex-wrap:wrap;gap:1rem}.employee-name{align-items:center;display:flex;font-weight:500;gap:.75rem}.employee-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#ec4899);border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:.875rem;font-weight:600;height:2rem;justify-content:center;width:2rem}.action-buttons{display:flex;gap:.5rem}.clock-card{background:linear-gradient(135deg,var(--gray-700) 0,var(--gray-800) 100%);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);color:#fff;margin-bottom:2rem;padding:2rem}.clock-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:1.5rem}.clock-date-time{flex:1 1}.current-date{font-size:1.125rem;font-weight:500;margin-bottom:.5rem;opacity:.95}.current-time{font-feature-settings:"tnum";font-size:2.5rem;font-variant-numeric:tabular-nums;font-weight:700;letter-spacing:-.02em}.clock-status{align-items:center;display:flex}.status-badge{align-items:center;border-radius:var(--radius);display:inline-flex;font-size:.875rem;font-weight:600;gap:.5rem;padding:.5rem 1rem}.status-clocked-in{background:#10b98133;border:2px solid #10b98180;color:#d1fae5}.status-not-clocked{background:#fb923c33;border:2px solid #fb923c80;color:#fed7aa}.clock-details{-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#ffffff26;border-radius:var(--radius);margin-bottom:1.5rem;padding:1.5rem}.time-info{gap:1.5rem;justify-content:space-around}.time-info,.time-item{align-items:center;display:flex}.time-item{flex:1 1;flex-direction:column;gap:.5rem}.time-label{font-size:.75rem;font-weight:600;letter-spacing:.05em;opacity:.8;text-transform:uppercase}.time-value{font-feature-settings:"tnum";font-size:1.5rem;font-variant-numeric:tabular-nums;font-weight:700}.time-divider{background:#ffffff4d;height:3rem;width:1px}.no-record-message{padding:2rem 1rem;text-align:center}.no-record-message p{font-size:1rem;margin:0;opacity:.9}.clock-actions{display:flex;gap:1rem;justify-content:center}.clock-btn{border:none;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f;font-size:1.125rem;min-width:200px;padding:1rem 2rem;transition:all .2s}.clock-btn:hover:not(:disabled){box-shadow:0 10px 15px -3px #0003,0 4px 6px -2px #0000001a;transform:translateY(-2px)}.clock-btn:active:not(:disabled){transform:translateY(0)}.clock-btn:disabled{cursor:not-allowed;opacity:.6}.completed-message{align-items:center;background:#fff3;border-radius:var(--radius);display:flex;font-size:1.125rem;font-weight:500;gap:.75rem;padding:1rem 2rem}.check-icon{font-size:1.5rem}.alert{border-radius:var(--radius);font-size:.9375rem;margin-bottom:1rem;padding:1rem}.alert-error{background:#ef444433;border:1px solid #ef444480;color:#fecaca}.alert-success{background:#10b98133;border:1px solid #10b98180;color:#d1fae5}.info-card{background:var(--info-light);border-left:4px solid var(--info)}@media (max-width:768px){.clock-card{padding:1.5rem}.clock-header{flex-direction:column;gap:1rem}.current-time{font-size:2rem}.time-info{flex-direction:column;gap:1rem}.time-divider{display:none}.time-item{background:#ffffff1a;border-radius:var(--radius);flex-direction:row;justify-content:space-between;padding:.75rem;width:100%}.clock-actions{flex-direction:column}.clock-btn{min-width:auto;width:100%}}
/*# sourceMappingURL=main.8d084c76.css.map*/