*{margin:0;padding:0;box-sizing:border-box}:root{--bg-primary: #0f0f23;--bg-secondary: #1a1a2e;--bg-card: #16162a;--text-primary: #e2e8f0;--text-secondary: #94a3b8;--accent: #6366f1;--accent-hover: #4f46e5;--success: #22c55e;--warning: #f59e0b;--error: #ef4444;--border: #2d2d4a}html,body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased}#root{min-height:100vh}.app{min-height:100vh;display:flex;flex-direction:column}.main-content{flex:1;padding:1rem 1rem 5rem}.loading-screen{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--bg-primary)}.spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.navbar{background:var(--bg-secondary);padding:1rem;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100}.navbar-brand{font-size:1.25rem;font-weight:700;color:var(--accent)}.navbar-user{display:flex;align-items:center;gap:1rem}.navbar-name{font-size:.875rem;color:var(--text-secondary)}.navbar-links{display:flex;gap:.5rem}.navbar-links a{color:var(--text-secondary);text-decoration:none;padding:.5rem .75rem;border-radius:.5rem;font-size:.875rem;transition:all .2s}.navbar-links a:hover,.navbar-links a.active{background:var(--bg-card);color:var(--text-primary)}.btn-logout{background:transparent;border:1px solid var(--error);color:var(--error);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-logout:hover{background:var(--error);color:#fff}.form-group{margin-bottom:1rem}.form-group label{display:block;margin-bottom:.5rem;font-size:.875rem;color:var(--text-secondary)}.form-group input{width:100%;padding:.75rem 1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:1rem;transition:border-color .2s}.form-group input:focus{outline:none;border-color:var(--accent)}.form-group input::placeholder{color:var(--text-secondary)}.btn{display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.5rem;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s;border:none;text-decoration:none}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover{background:var(--accent-hover)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-success{background:var(--success);color:#fff}.btn-warning{background:var(--warning);color:#1a1a2e}.btn-block{width:100%}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;margin-bottom:1rem}.card-title{font-size:1rem;font-weight:600;margin-bottom:.75rem;color:var(--text-primary)}.login-container{min-height:100vh;display:flex;flex-direction:column;justify-content:center;align-items:center;padding:2rem}.login-logo{font-size:3rem;margin-bottom:.5rem}.login-title{font-size:1.75rem;font-weight:700;color:var(--accent);margin-bottom:2rem}.login-form{width:100%;max-width:360px}.login-error{background:#ef44441a;border:1px solid var(--error);color:var(--error);padding:.75rem;border-radius:.5rem;margin-bottom:1rem;font-size:.875rem;text-align:center}.login-toggle{text-align:center;margin-top:1.5rem;color:var(--text-secondary);font-size:.875rem}.login-toggle button{background:none;border:none;color:var(--accent);cursor:pointer;font-size:.875rem;text-decoration:underline}.dashboard{max-width:480px;margin:0 auto}.dashboard-clock{text-align:center;padding:2rem 0}.clock-time{font-size:3.5rem;font-weight:700;font-variant-numeric:tabular-nums;letter-spacing:-2px}.clock-date{color:var(--text-secondary);margin-top:.5rem}.dashboard-status{text-align:center;padding:1rem;border-radius:.75rem;margin-bottom:1.5rem}.dashboard-status.working{background:#22c55e1a;border:1px solid var(--success)}.dashboard-status.not-working{background:#94a3b81a;border:1px solid var(--text-secondary)}.status-text{font-weight:600}.status-text.working{color:var(--success)}.status-time{font-size:.875rem;color:var(--text-secondary);margin-top:.25rem}.punch-container{display:flex;justify-content:center;padding:2rem 0}.punch-button{width:180px;height:180px;border-radius:50%;border:none;font-size:1.25rem;font-weight:700;cursor:pointer;transition:all .3s;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.5rem;box-shadow:0 4px 20px #0000004d}.punch-button.entry{background:linear-gradient(135deg,var(--success),#16a34a);color:#fff}.punch-button.exit{background:linear-gradient(135deg,var(--warning),#d97706);color:#1a1a2e}.punch-button:hover{transform:scale(1.05)}.punch-button:active{transform:scale(.98)}.punch-button:disabled{opacity:.6;cursor:not-allowed;transform:none}.punch-icon{font-size:2.5rem}.time-card{margin-top:1rem}.time-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.time-card-total{color:var(--accent);font-weight:600}.punch-list{list-style:none}.punch-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 0;border-bottom:1px solid var(--border)}.punch-item:last-child{border-bottom:none}.punch-type{display:flex;align-items:center;gap:.5rem}.punch-type-icon{width:8px;height:8px;border-radius:50%}.punch-type-icon.in{background:var(--success)}.punch-type-icon.out{background:var(--warning)}.punch-timestamp{font-variant-numeric:tabular-nums}.punch-location{font-size:.75rem;color:var(--text-secondary)}.no-punches{text-align:center;color:var(--text-secondary);padding:2rem 0}.admin-container{max-width:800px;margin:0 auto}.admin-tabs{display:flex;gap:.5rem;margin-bottom:1.5rem;border-bottom:1px solid var(--border);padding-bottom:.5rem}.admin-tab{background:transparent;border:none;color:var(--text-secondary);padding:.75rem 1rem;cursor:pointer;font-size:.875rem;border-radius:.5rem .5rem 0 0;transition:all .2s}.admin-tab.active{background:var(--bg-card);color:var(--accent)}.employee-list{list-style:none}.employee-item{display:flex;justify-content:space-between;align-items:center;padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;margin-bottom:.5rem;cursor:pointer;transition:border-color .2s}.employee-item:hover{border-color:var(--accent)}.employee-item.selected{border-color:var(--accent);background:#6366f11a}.employee-info h4{font-size:1rem;margin-bottom:.25rem}.employee-info p{font-size:.875rem;color:var(--text-secondary)}.employee-status{display:flex;align-items:center;gap:.5rem;font-size:.875rem}.status-dot{width:8px;height:8px;border-radius:50%}.status-dot.working{background:var(--success)}.status-dot.not-working{background:var(--text-secondary)}.records-filter{display:flex;gap:.5rem;margin-bottom:1rem;flex-wrap:wrap}.records-filter input{padding:.5rem .75rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:.875rem}.records-filter input:focus{outline:none;border-color:var(--accent)}.records-table{width:100%;border-collapse:collapse;font-size:.875rem}.records-table th,.records-table td{padding:.75rem .5rem;text-align:left;border-bottom:1px solid var(--border)}.records-table th{color:var(--text-secondary);font-weight:500}.records-table tr:hover{background:var(--bg-secondary)}.reports-container{max-width:800px;margin:0 auto}.reports-header{display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:1rem;margin-bottom:1.5rem}.reports-filters{display:flex;gap:.5rem;flex-wrap:wrap}.btn-export{background:var(--bg-card);border:1px solid var(--border);color:var(--text-primary);padding:.5rem 1rem;border-radius:.5rem;cursor:pointer;font-size:.875rem;transition:all .2s}.btn-export:hover{border-color:var(--accent)}.report-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:1rem;margin-bottom:1.5rem}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1rem;text-align:center}.summary-value{font-size:1.5rem;font-weight:700;color:var(--accent)}.summary-label{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}@media(max-width:480px){.navbar{flex-wrap:wrap;gap:.5rem}.navbar-user{width:100%;justify-content:space-between}.clock-time{font-size:2.5rem}.punch-button{width:150px;height:150px;font-size:1rem}.punch-icon{font-size:2rem}.records-table{font-size:.75rem}.records-table th,.records-table td{padding:.5rem .25rem}}.face-camera-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000f2;z-index:9999;display:flex;align-items:center;justify-content:center;padding:1rem}.face-camera-container{background:var(--bg-secondary);border-radius:1rem;width:100%;max-width:480px;overflow:hidden;position:relative}.face-camera-close{position:absolute;top:.75rem;right:.75rem;z-index:10;width:32px;height:32px;border-radius:50%;background:#0009;color:#fff;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;border:none}.face-camera-view{position:relative;background:#000;width:100%;aspect-ratio:4/3}.face-camera-video{width:100%;height:100%;object-fit:cover;transform:scaleX(-1)}.face-camera-canvas{position:absolute;top:0;left:0;width:100%;height:100%;transform:scaleX(-1)}.face-camera-status{padding:1rem;text-align:center;display:flex;align-items:center;justify-content:center;gap:.5rem;min-height:3.5rem}.face-camera-status p{color:var(--text-secondary);font-size:.9rem}.face-camera-status.status-error p{color:var(--error)}.face-camera-status.status-capturing p{color:var(--success)}.face-camera-spinner{width:20px;height:20px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .8s linear infinite}.face-camera-actions{padding:1rem}.face-camera-capturing{display:flex;align-items:center;justify-content:center;gap:.5rem;color:var(--accent)}.face-preview{display:flex;flex-direction:column;align-items:center;gap:.5rem;padding:.75rem;background:var(--bg-card);border-radius:.5rem;border:2px solid var(--success)}.face-preview img{width:120px;height:120px;border-radius:50%;object-fit:cover;border:3px solid var(--success)}.face-preview-check{color:var(--success);font-size:.85rem;font-weight:600}.face-capture-btn{background:var(--accent)!important;color:#fff!important;font-size:1rem!important;padding:.75rem!important;transition:background .2s}.face-capture-btn:hover{background:var(--accent-hover)!important}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:1.5rem;font-size:.95rem}.register-cta{text-align:center;margin-top:1rem;padding:1rem 0;border-top:1px solid var(--border)}.register-cta p{color:var(--text-secondary);margin-bottom:.5rem}.btn-accent{background:var(--success)!important;color:#fff!important;font-weight:600!important}.btn-outline{background:transparent!important;border:1px solid var(--border)!important;color:var(--text-secondary)!important}.btn-sm{padding:.25rem .75rem!important;font-size:.8rem!important}.dashboard-header{text-align:center;margin-bottom:1rem}.dashboard-user{font-size:1rem;color:var(--text-secondary)}.dashboard-admin{padding:0}.stats-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:1rem;margin-bottom:1.5rem}.stat-card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;text-align:center;transition:transform .2s,border-color .2s}.stat-card:hover{transform:translateY(-2px);border-color:var(--accent)}.stat-card.working{border-color:var(--success);background:#22c55e1a}.stat-icon{font-size:1.75rem;margin-bottom:.5rem}.stat-value{font-size:2rem;font-weight:700;color:var(--text-primary)}.stat-label{font-size:.75rem;color:var(--text-secondary);margin-top:.25rem}.recent-punches{display:flex;flex-direction:column;gap:.5rem}.punch-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem 1rem;background:var(--bg-secondary);border-radius:.5rem;border-left:3px solid var(--text-secondary)}.punch-item.in{border-left-color:var(--success)}.punch-item.out{border-left-color:var(--warning)}.punch-user{font-weight:600;color:var(--text-primary)}.punch-info{display:flex;align-items:center;gap:1rem;font-size:.875rem}.punch-type{font-weight:500}.punch-type.in{color:var(--success)}.punch-type.out{color:var(--warning)}.punch-time{color:var(--text-secondary)}.employee-list{display:flex;flex-direction:column;gap:.75rem}.employee-card{display:flex;align-items:center;gap:1rem;padding:1rem;background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;cursor:pointer;transition:all .2s}.employee-card:hover{border-color:var(--accent);transform:translate(4px)}.employee-card.selected{border-color:var(--accent);background:#6366f11a}.employee-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent),var(--accent-hover));display:flex;align-items:center;justify-content:center;font-size:1.25rem;font-weight:700;color:#fff;flex-shrink:0}.employee-info{flex:1;min-width:0}.employee-info h4{font-size:1rem;font-weight:600;margin-bottom:.25rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-info p{font-size:.875rem;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.employee-meta{display:flex;gap:.5rem;margin-top:.5rem;flex-wrap:wrap}.role-badge{font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem;background:var(--bg-secondary);color:var(--text-secondary)}.role-badge.admin{background:#6366f133;color:var(--accent)}.face-badge{font-size:.75rem;padding:.25rem .5rem;border-radius:.25rem}.face-badge.has-face{background:#22c55e33;color:var(--success)}.face-badge.no-face{background:#ef444433;color:var(--error)}.employee-arrow{color:var(--text-secondary);font-size:1.25rem}.employee-header{display:flex;align-items:center;gap:1rem;margin-bottom:1rem}.time-records{display:flex;flex-direction:column;gap:1rem}.records-filter{display:flex;gap:1rem;align-items:center;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:.5rem}.filter-group label{font-size:.875rem;color:var(--text-secondary)}.filter-group input[type=date]{padding:.5rem .75rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:.5rem;color:var(--text-primary);font-size:.875rem}.filter-group input[type=date]:focus{outline:none;border-color:var(--accent)}.day-card{border-left:3px solid var(--accent)}.day-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.day-date{font-weight:600;font-size:1rem}.day-hours{color:var(--accent);font-weight:600;font-size:.875rem}.day-records{display:flex;flex-direction:column;gap:.5rem}.record-item{display:flex;justify-content:space-between;align-items:center;padding:.75rem;background:var(--bg-secondary);border-radius:.5rem;border-left:3px solid transparent}.record-item.in{border-left-color:var(--success)}.record-item.out{border-left-color:var(--warning)}.record-type{font-size:.875rem;font-weight:500}.record-time{font-family:monospace;font-size:1rem;color:var(--text-primary)}.record-location{font-size:.75rem;color:var(--accent);text-decoration:none;transition:color .2s}.record-location:hover{color:var(--accent-hover);text-decoration:underline}@media(max-width:640px){.stats-grid{grid-template-columns:1fr}.stat-card{display:flex;align-items:center;gap:1rem;text-align:left}.stat-icon{margin-bottom:0}.punch-info{flex-direction:column;align-items:flex-end;gap:.25rem}.employee-card{flex-wrap:wrap}.employee-arrow{display:none}.records-filter{flex-direction:column;align-items:stretch}.filter-group{justify-content:space-between}}
