:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media (prefers-color-scheme: light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.user-registration-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.registration-content{background:#fff;border-radius:20px;padding:40px;box-shadow:0 15px 35px #0000001a;width:100%;max-width:600px;animation:slideUp .5s ease-out}.registration-content h2{text-align:center;color:#2c3e50;margin-bottom:10px;font-size:2rem;font-weight:600}.registration-info{text-align:center;color:#7f8c8d;margin-bottom:30px;padding:15px;background:#f8f9fa;border-radius:10px;border-left:4px solid #3498db}.registration-form{display:flex;flex-direction:column;gap:20px}.form-row{display:flex;gap:20px}.form-row .form-group{flex:1}.form-group label{font-weight:500;color:#2c3e50;margin-bottom:8px;font-size:.95rem}.form-group input{padding:12px 16px;border:2px solid #e1e8ed;border-radius:10px;font-size:1rem;transition:all .3s ease;background:#fafbfc}.form-group input:focus{outline:none;border-color:#3498db;background:#fff;box-shadow:0 0 0 3px #3498db1a}.form-group input::placeholder{color:#95a5a6}.error-message{background:#fee;color:#e74c3c;padding:12px 16px;border-radius:10px;border:1px solid #fadbd8;text-align:center;font-weight:500}.register-btn{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:16px 24px;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.register-btn:hover:not(:disabled){background:linear-gradient(135deg,#2980b9,#1f4e79);transform:translateY(-2px);box-shadow:0 8px 25px #3498db4d}.register-btn:disabled{background:#bdc3c7;cursor:not-allowed;transform:none;box-shadow:none}.back-btn{background:transparent;color:#7f8c8d;border:2px solid #e1e8ed;padding:12px 24px;border-radius:12px;font-size:1rem;cursor:pointer;transition:all .3s ease;margin-top:20px}.back-btn:hover{color:#2c3e50;border-color:#bdc3c7;background:#f8f9fa}@media (max-width: 768px){.registration-content{padding:30px 20px;margin:10px}.form-row{flex-direction:column;gap:15px}.registration-content h2{font-size:1.5rem}}@media (max-width: 480px){.user-registration-container{padding:10px}.registration-content{padding:25px 15px}}.registration-success-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#27ae60,#2ecc71);padding:20px}.success-content{background:#fff;border-radius:20px;padding:40px;box-shadow:0 15px 35px #0000001a;width:100%;max-width:600px;text-align:center;animation:successSlideUp .6s ease-out}@keyframes successSlideUp{0%{opacity:0;transform:translateY(50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.success-icon{font-size:4rem;margin-bottom:20px;animation:bounce 1s infinite}@keyframes bounce{0%,20%,50%,80%,to{transform:translateY(0)}40%{transform:translateY(-10px)}60%{transform:translateY(-5px)}}.success-content h2{color:#27ae60;margin-bottom:20px;font-size:2rem;font-weight:600}.user-info{background:#f8f9fa;border-radius:15px;padding:20px;margin-bottom:30px;border-left:4px solid #27ae60}.welcome-message{color:#2c3e50;font-size:1.2rem;margin:0}.user-id-section{background:#e8f8f5;border-radius:15px;padding:25px;margin-bottom:30px;border:2px solid #27ae60}.user-id-section h3{color:#27ae60;margin-bottom:15px;font-size:1.3rem}.user-id-display{display:flex;align-items:center;justify-content:center;gap:15px;margin-bottom:10px}.user-id{background:#fff;color:#2c3e50;font-size:2.5rem;font-weight:700;padding:15px 25px;border-radius:12px;border:3px solid #27ae60;letter-spacing:2px;font-family:Courier New,monospace;min-width:200px}.copy-btn{background:#27ae60;color:#fff;border:none;padding:12px 15px;border-radius:10px;cursor:pointer;font-size:1.2rem;transition:all .3s ease}.copy-btn:hover{background:#219a52;transform:scale(1.1)}.copy-success{color:#27ae60;font-weight:500;margin:5px 0 0;animation:fadeIn .3s ease-in}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.important-notice{background:#fff3cd;border:2px solid #ffc107;border-radius:15px;padding:20px;margin-bottom:25px;display:flex;align-items:flex-start;gap:15px;text-align:left}.notice-icon{font-size:2rem;flex-shrink:0}.notice-content h4{color:#856404;margin:0 0 10px;font-size:1.2rem}.notice-content p{color:#856404;margin:0 0 15px;line-height:1.5}.notice-content ul{color:#856404;margin:0;padding-left:20px}.notice-content li{margin-bottom:5px}.next-steps{background:#e3f2fd;border-radius:15px;padding:20px;margin-bottom:30px;text-align:left;border-left:4px solid #2196f3}.next-steps h4{color:#1976d2;margin:0 0 15px;font-size:1.2rem}.next-steps ol{color:#1976d2;margin:0;padding-left:20px}.next-steps li{margin-bottom:8px;line-height:1.5}.continue-btn{background:linear-gradient(135deg,#27ae60,#219a52);color:#fff;border:none;padding:16px 32px;border-radius:12px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px}.continue-btn:hover{background:linear-gradient(135deg,#219a52,#1e8449);transform:translateY(-2px);box-shadow:0 8px 25px #27ae604d}@media (max-width: 768px){.success-content{padding:30px 20px;margin:10px}.user-id{font-size:2rem;padding:12px 20px;min-width:160px}.success-content h2{font-size:1.5rem}.important-notice{flex-direction:column;text-align:center}.notice-content{text-align:left}}@media (max-width: 480px){.registration-success-container{padding:10px}.success-content{padding:25px 15px}.user-id-display{flex-direction:column;gap:10px}.user-id{font-size:1.8rem;padding:10px 15px;min-width:auto}}.home-container{width:100vw;min-height:100vh;display:flex;flex-direction:column;background:linear-gradient(135deg,#667eea,#764ba2)}.home-header{background:#ffffff1a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:2rem;text-align:center;color:#fff;position:relative}.home-header h1{font-size:3rem;margin:0 0 .5rem;font-weight:700;text-shadow:2px 2px 4px rgba(0,0,0,.3)}.home-header p{font-size:1.2rem;margin:0;opacity:.9}.header-buttons{position:absolute;top:2rem;right:2rem;display:flex;gap:15px;flex-wrap:wrap}.signin-link,.register-link{background:#fff3;color:#fff;text-decoration:none;padding:.8rem 1.5rem;border-radius:25px;font-weight:600;transition:all .3s ease;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.3);cursor:pointer;font-size:.9rem}.register-link{background:#27ae6033;border:1px solid rgba(39,174,96,.3)}.signin-link:hover,.register-link:hover{background:#ffffff4d;transform:translateY(-2px);box-shadow:0 4px 15px #0003}.register-link:hover{background:#27ae604d}.home-content{flex:1;display:flex;justify-content:center;align-items:center;padding:2rem}.home-footer{background:#0003;color:#fff;text-align:center;padding:1rem;font-size:.9rem;opacity:.8}.home-footer p{margin:0}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;gap:1.5rem}.loading-spinner{width:60px;height:60px;border:4px solid rgba(255,255,255,.3);border-left:4px solid white;border-radius:50%;animation:spin 1s linear infinite}.loading-container p{font-size:1.2rem;font-weight:500;margin:0}@media (max-width: 768px){.home-header{padding:1.5rem 1rem}.home-header h1{font-size:2rem}.home-header p{font-size:1rem}.header-buttons{position:static;justify-content:center;margin-top:1rem}.signin-link,.register-link{padding:.7rem 1.2rem;font-size:.8rem}.home-content{padding:1rem}}.attendance-form-container{background:#fff;border-radius:20px;padding:40px;box-shadow:0 15px 35px #0000001a;width:100%;max-width:500px;animation:slideUp .5s ease-out}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.attendance-form-container h2{text-align:center;color:#2c3e50;margin-bottom:10px;font-size:2rem;font-weight:600}.form-description{text-align:center;color:#7f8c8d;margin-bottom:30px;line-height:1.5}.attendance-form{display:flex;flex-direction:column;gap:25px}.form-group{display:flex;flex-direction:column}.form-group label{font-weight:500;color:#2c3e50;margin-bottom:10px;font-size:1rem}.user-id-input{padding:16px 20px;border:3px solid #e1e8ed;border-radius:15px;font-size:1.5rem;font-weight:700;text-align:center;letter-spacing:2px;font-family:Courier New,monospace;transition:all .3s ease;background:#fafbfc}.user-id-input:focus{outline:none;border-color:#3498db;background:#fff;box-shadow:0 0 0 4px #3498db1a}.user-id-input::placeholder{color:#bdc3c7;font-weight:400}.attendance-type-buttons{display:flex;gap:15px;margin-top:10px}.type-btn{flex:1;padding:16px 20px;border:3px solid #e1e8ed;border-radius:15px;background:#fafbfc;color:#7f8c8d;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;gap:8px}.type-btn:hover{border-color:#bdc3c7;background:#fff;transform:translateY(-2px)}.type-btn.active{border-color:#3498db;background:#3498db;color:#fff;transform:translateY(-2px);box-shadow:0 5px 15px #3498db4d}.message{padding:15px 20px;border-radius:12px;text-align:center;font-weight:500;margin:10px 0}.message.success{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.message.error{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.submit-btn{background:linear-gradient(135deg,#3498db,#2980b9);color:#fff;border:none;padding:18px 24px;border-radius:15px;font-size:1.2rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:10px;display:flex;align-items:center;justify-content:center;gap:10px}.submit-btn:hover:not(:disabled){background:linear-gradient(135deg,#2980b9,#1f4e79);transform:translateY(-3px);box-shadow:0 10px 30px #3498db66}.submit-btn:disabled{background:#bdc3c7;cursor:not-allowed;transform:none;box-shadow:none}@media (max-width: 768px){.attendance-form-container{padding:30px 20px;margin:10px}.attendance-form-container h2{font-size:1.5rem}.user-id-input{font-size:1.3rem;padding:14px 18px}.attendance-type-buttons{flex-direction:column;gap:12px}.type-btn{padding:14px 18px;font-size:1rem}}@media (max-width: 480px){.attendance-form-container{padding:25px 15px}.user-id-input{font-size:1.2rem;padding:12px 16px}.submit-btn{padding:16px 20px;font-size:1.1rem}}.signin-container{width:100vw;min-height:100vh;display:flex;justify-content:center;align-items:center;padding:2rem;background:linear-gradient(135deg,#667eea,#764ba2)}.signin-content{max-width:400px;width:100%;padding:3rem 2rem;background:#fff;border-radius:16px;box-shadow:0 20px 40px #0000001a}.signin-content h2{text-align:center;color:#333;margin-bottom:1rem;font-size:1.8rem;font-weight:700}.admin-info{text-align:center;color:#e67e22;background:#fef9e7;padding:15px;border-radius:10px;border:1px solid #f39c12;margin-bottom:2rem;font-weight:500;font-size:.9rem}.signin-form{display:flex;flex-direction:column;gap:1.5rem}.form-group{display:flex;flex-direction:column;gap:.5rem}.form-group label{font-weight:600;color:#555;font-size:.95rem}.form-group input{padding:1rem;border:2px solid #e1e5e9;border-radius:8px;font-size:1rem;transition:border-color .3s ease;background:#fff}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.error-message{background:#fee2e2;color:#dc2626;padding:.75rem;border-radius:8px;font-size:.9rem;text-align:center;border:1px solid #fecaca}.signin-btn{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1.1rem;font-weight:600;cursor:pointer;transition:all .3s ease;margin-top:1rem}.signin-btn:hover:not(:disabled){background:linear-gradient(135deg,#5a67d8,#6b46c1);transform:translateY(-2px);box-shadow:0 6px 20px #667eea4d}.signin-btn:disabled{opacity:.7;cursor:not-allowed}.back-to-home-btn{background:#6b7280;color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-size:1rem;cursor:pointer;transition:all .3s ease;margin-top:1.5rem;width:100%}.back-to-home-btn:hover{background:#4b5563;transform:translateY(-1px)}@media (max-width: 768px){.signin-container{padding:1rem}.signin-content{padding:2rem 1.5rem}.signin-content h2{font-size:1.5rem}}.admin-container{width:100vw;margin:0 auto;padding:2rem;background:#f8fafc;min-height:100vh}.admin-header{display:flex;justify-content:space-between;align-items:center;background:#fff;padding:1.5rem 2rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem}.admin-header h1{color:#1f2937;margin:0;font-size:2rem;font-weight:700}.signout-btn{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff;border:none;padding:.8rem 1.5rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.signout-btn:hover{background:linear-gradient(135deg,#dc2626,#b91c1c);transform:translateY(-1px)}.admin-controls{background:#fff;padding:2rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;margin-bottom:2rem}.filter-controls h3{color:#374151;margin-bottom:1rem;font-size:1.2rem}.filter-buttons{display:flex;gap:.8rem;flex-wrap:wrap;margin-bottom:2rem}.filter-buttons button{padding:.7rem 1.2rem;border:2px solid #e5e7eb;background:#fff;border-radius:8px;cursor:pointer;transition:all .3s ease;font-weight:500;color:#6b7280}.filter-buttons button:hover{border-color:#3b82f6;color:#3b82f6}.filter-buttons button.active{background:linear-gradient(135deg,#3b82f6,#2563eb);color:#fff;border-color:#3b82f6}.export-controls{display:flex;justify-content:flex-end}.export-btn{background:linear-gradient(135deg,#10b981,#059669);color:#fff;border:none;padding:1rem 2rem;border-radius:8px;font-size:1rem;font-weight:600;cursor:pointer;transition:all .3s ease}.export-btn:hover{background:linear-gradient(135deg,#059669,#047857);transform:translateY(-2px);box-shadow:0 4px 15px #10b9814d}.employee-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem}.stat-card{background:#fff;padding:1.5rem;border-radius:12px;box-shadow:0 2px 10px #0000001a;text-align:center}.stat-card h4{color:#6b7280;margin:0 0 .5rem;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.stat-number{color:#1f2937;font-size:2.5rem;font-weight:700}.employee-table-container{background:#fff;border-radius:12px;box-shadow:0 2px 10px #0000001a;overflow:hidden}.employee-table{width:100%;border-collapse:collapse}.employee-table thead{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.employee-table th,.employee-table td{padding:1rem;text-align:left;border-bottom:1px solid #e5e7eb}.employee-table th{font-weight:600;font-size:.9rem;text-transform:uppercase;letter-spacing:.5px}.employee-table tbody tr:hover{background:#f9fafb}.employee-photo{width:50px;height:50px;border-radius:50%;object-fit:cover;border:2px solid #e5e7eb}.status-badge{padding:.4rem .8rem;border-radius:20px;font-size:.8rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.status-badge.full-time{background:#d1fae5;color:#065f46}.status-badge.part-time{background:#fef3c7;color:#92400e}.status-badge.check-in{background:#d1fae5;color:#065f46}.status-badge.check-out{background:#fee2e2;color:#991b1b}.user-id{font-family:Courier New,monospace;font-weight:700;background:#e9ecef;padding:4px 8px;border-radius:6px;color:#495057;font-size:.9rem}.no-data{padding:3rem;text-align:center;color:#6b7280}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;gap:1rem}@media (max-width: 768px){.admin-container{padding:1rem}.admin-header{flex-direction:column;gap:1rem;text-align:center}.admin-header h1{font-size:1.5rem}.filter-buttons{justify-content:center}.filter-buttons button{padding:.6rem 1rem;font-size:.9rem}.export-controls{justify-content:center}.employee-table-container{overflow-x:auto}.employee-table{min-width:800px}.employee-table th,.employee-table td{padding:.8rem .6rem;font-size:.9rem}.employee-photo{width:40px;height:40px}}*{box-sizing:border-box}#root{margin:0;padding:0;min-height:100vh}body{margin:0;padding:0;font-family:Inter,system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light;color:#213547;background-color:#fff;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.loading-container{display:flex;flex-direction:column;justify-content:center;align-items:center;min-height:100vh;gap:1rem;background:#f8fafc}.loading-spinner{width:50px;height:50px;border:4px solid #e5e7eb;border-left:4px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-container p{color:#6b7280;font-size:1rem;margin:0}@media (max-width: 768px){body{font-size:14px}}button{font-family:inherit;outline:none}input,select,textarea{font-family:inherit}a{color:inherit;text-decoration:none}
