@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";:root{--bg-primary:#0a0e1a;--bg-secondary:#111827;--bg-card:#1a2235;--bg-card-hover:#1f2942;--bg-input:#0f1629;--border:#2a3450;--border-focus:#6366f1;--text-primary:#f1f5f9;--text-secondary:#94a3b8;--text-muted:#64748b;--accent:#6366f1;--accent-hover:#818cf8;--accent-glow:#6366f140;--success:#10b981;--success-bg:#10b9811f;--warning:#f59e0b;--warning-bg:#f59e0b1f;--danger:#ef4444;--danger-bg:#ef44441f;--info:#3b82f6;--info-bg:#3b82f61f;--gradient-1:linear-gradient(135deg, #6366f1, #8b5cf6);--gradient-2:linear-gradient(135deg, #10b981, #06b6d4);--gradient-3:linear-gradient(135deg, #f59e0b, #ef4444);--gradient-4:linear-gradient(135deg, #3b82f6, #6366f1);--radius:12px;--radius-sm:8px;--radius-lg:16px;--shadow:0 4px 24px #0000004d;--shadow-lg:0 8px 40px #0006;--transition:all .25s cubic-bezier(.4, 0, .2, 1);--sidebar-width:260px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{background:var(--bg-primary);color:var(--text-primary);min-height:100vh;font-family:Inter,sans-serif;line-height:1.6;overflow-x:hidden}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-muted)}.app-layout{min-height:100vh;display:flex}.sidebar{width:var(--sidebar-width);background:var(--bg-secondary);border-right:1px solid var(--border);z-index:100;transition:var(--transition);flex-direction:column;padding:24px 0;display:flex;position:fixed;top:0;bottom:0;left:0}.sidebar-logo{border-bottom:1px solid var(--border);margin-bottom:16px;padding:0 24px 24px}.sidebar-logo h1{background:var(--gradient-1);-webkit-text-fill-color:transparent;letter-spacing:-.5px;-webkit-background-clip:text;font-size:1.25rem;font-weight:800}.sidebar-logo p{color:var(--text-muted);margin-top:4px;font-size:.75rem}.sidebar-nav{flex:1;padding:0 12px;overflow-y:auto}.nav-section{text-transform:uppercase;letter-spacing:1.5px;color:var(--text-muted);padding:16px 12px 8px;font-size:.65rem;font-weight:700}.nav-item{border-radius:var(--radius-sm);color:var(--text-secondary);cursor:pointer;transition:var(--transition);align-items:center;gap:12px;margin-bottom:2px;padding:10px 16px;font-size:.875rem;font-weight:500;text-decoration:none;display:flex;position:relative}.nav-item:hover{background:var(--bg-card);color:var(--text-primary);text-decoration:none}.nav-item.active{background:var(--accent-glow);color:var(--accent-hover);text-decoration:none}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 3px 3px 0;width:3px;height:60%;position:absolute;top:50%;left:0;transform:translateY(-50%)}.nav-item .icon{text-align:center;width:24px;font-size:1.15rem}.nav-badge{background:var(--danger);color:#fff;text-align:center;border-radius:10px;min-width:20px;margin-left:auto;padding:2px 7px;font-size:.65rem;font-weight:700}a{text-decoration:none}.main-content{margin-left:var(--sidebar-width);flex:1;min-height:100vh;padding:24px 32px}.page-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;margin-bottom:28px;display:flex}.page-header h2{letter-spacing:-.5px;font-size:1.65rem;font-weight:700}.page-header .subtitle{color:var(--text-muted);margin-top:2px;font-size:.85rem}.header-actions{align-items:center;gap:10px;display:flex}.btn{border-radius:var(--radius-sm);cursor:pointer;transition:var(--transition);white-space:nowrap;border:none;align-items:center;gap:8px;padding:10px 20px;font-family:inherit;font-size:.85rem;font-weight:600;display:inline-flex}.btn-primary{background:var(--gradient-1);color:#fff;box-shadow:0 4px 15px var(--accent-glow)}.btn-primary:hover{box-shadow:0 6px 20px var(--accent-glow);transform:translateY(-1px)}.btn-secondary{background:var(--bg-card);color:var(--text-primary);border:1px solid var(--border)}.btn-secondary:hover{border-color:var(--accent);background:var(--bg-card-hover)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover{background:#dc2626}.btn-success{background:var(--success);color:#fff}.btn-sm{padding:6px 14px;font-size:.78rem}.btn-icon{justify-content:center;width:36px;height:36px;padding:8px}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);padding:24px}.card:hover{border-color:var(--border-focus)}.kpi-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:16px;margin-bottom:28px;display:grid}.kpi-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);padding:20px 24px;position:relative;overflow:hidden}.kpi-card:before{content:"";height:3px;position:absolute;top:0;left:0;right:0}.kpi-card.accent:before{background:var(--gradient-1)}.kpi-card.success:before{background:var(--gradient-2)}.kpi-card.warning:before{background:var(--gradient-3)}.kpi-card.info:before{background:var(--gradient-4)}.kpi-card:hover{box-shadow:var(--shadow);transform:translateY(-2px)}.kpi-header{justify-content:space-between;align-items:flex-start;margin-bottom:12px;display:flex}.kpi-label{color:var(--text-muted);font-size:.78rem;font-weight:500}.kpi-icon{border-radius:var(--radius-sm);justify-content:center;align-items:center;width:40px;height:40px;font-size:1.15rem;display:flex}.kpi-card.accent .kpi-icon{background:var(--accent-glow)}.kpi-card.success .kpi-icon{background:var(--success-bg)}.kpi-card.warning .kpi-icon{background:var(--warning-bg)}.kpi-card.info .kpi-icon{background:var(--info-bg)}.kpi-value{letter-spacing:-1px;margin-bottom:4px;font-size:2rem;font-weight:800;line-height:1}.kpi-change{border-radius:20px;align-items:center;gap:4px;padding:2px 8px;font-size:.75rem;font-weight:600;display:inline-flex}.kpi-change.up{background:var(--success-bg);color:var(--success)}.kpi-change.down{background:var(--danger-bg);color:var(--danger)}.table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);overflow:hidden}.table-header{border-bottom:1px solid var(--border);flex-wrap:wrap;justify-content:space-between;align-items:center;gap:12px;padding:16px 20px;display:flex}.table-header h3{font-size:1rem;font-weight:600}table{border-collapse:collapse;width:100%}th{text-align:left;text-transform:uppercase;letter-spacing:1px;color:var(--text-muted);background:var(--bg-input);border-bottom:1px solid var(--border);padding:12px 16px;font-size:.72rem;font-weight:700}td{border-bottom:1px solid var(--border);vertical-align:middle;padding:14px 16px;font-size:.85rem}tr:last-child td{border-bottom:none}tr:hover td{background:var(--bg-card-hover)}.badge{border-radius:20px;align-items:center;gap:5px;padding:4px 10px;font-size:.72rem;font-weight:600;display:inline-flex}.badge-success{background:var(--success-bg);color:var(--success)}.badge-warning{background:var(--warning-bg);color:var(--warning)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-neutral{color:var(--text-secondary);background:#94a3b81f}.form-group{margin-bottom:18px}.form-label{color:var(--text-secondary);margin-bottom:6px;font-size:.8rem;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--transition);padding:10px 14px;font-family:inherit;font-size:.85rem}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.form-textarea{resize:vertical;min-height:80px}.form-row{grid-template-columns:1fr 1fr;gap:16px;display:grid}.modal-overlay{-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:200;background:#0009;justify-content:center;align-items:center;padding:20px;animation:.2s fadeInOverlay;display:flex;position:fixed;inset:0}@keyframes fadeInOverlay{0%{opacity:0}to{opacity:1}}.modal{background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-lg);width:100%;max-width:540px;max-height:85vh;animation:.25s cubic-bezier(.4,0,.2,1) slideInModal;overflow-y:auto}@keyframes slideInModal{0%{opacity:0;transform:translateY(20px)scale(.95)}to{opacity:1;transform:translateY(0)scale(1)}}.modal-header{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:20px 24px;display:flex}.modal-header h3{font-size:1.1rem;font-weight:700}.modal-close{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;padding:4px;font-size:1.25rem}.modal-close:hover{color:var(--text-primary)}.modal-body,.modal-content{padding:24px}.modal-footer{border-top:1px solid var(--border);justify-content:flex-end;gap:10px;padding:16px 24px;display:flex}.search-box{width:280px;position:relative}.search-box .icon{color:var(--text-muted);font-size:.9rem;position:absolute;top:50%;left:12px;transform:translateY(-50%)}.search-box input{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--radius-sm);width:100%;color:var(--text-primary);transition:var(--transition);padding:9px 14px 9px 36px;font-family:inherit;font-size:.83rem}.search-box input:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow);outline:none}.avatar{color:#fff;border-radius:50%;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:.8rem;font-weight:700;display:flex}.employee-cell{align-items:center;gap:12px;display:flex}.employee-cell .name{font-weight:600}.employee-cell .role{color:var(--text-muted);font-size:.75rem}.charts-grid{grid-template-columns:1fr 1fr;gap:20px;margin-bottom:28px;display:grid}.chart-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);padding:20px}.chart-card h3{margin-bottom:16px;font-size:.95rem;font-weight:600}.chart-card canvas{width:100%!important}.pointage-grid{grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:14px;display:grid}.pointage-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius);transition:var(--transition);align-items:center;gap:14px;padding:16px 20px;display:flex}.pointage-card:hover{border-color:var(--accent)}.pointage-card .info{flex:1}.pointage-card .name{font-size:.9rem;font-weight:600}.pointage-card .role{color:var(--text-muted);font-size:.75rem}.pointage-status{gap:6px;margin-top:8px;display:flex}.status-dot{background:var(--border);border-radius:50%;width:10px;height:10px}.status-dot.present{background:var(--success);box-shadow:0 0 8px var(--success)}.status-dot.late{background:var(--warning);box-shadow:0 0 8px var(--warning)}.status-dot.absent{background:var(--danger);box-shadow:0 0 8px var(--danger)}.pointage-actions{gap:6px;display:flex}.pointage-btn{border-radius:var(--radius-sm);border:1px solid var(--border);background:var(--bg-input);width:34px;height:34px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;font-size:.85rem;display:flex}.pointage-btn:hover{border-color:var(--accent);color:var(--accent)}.pointage-btn.checked{background:var(--success);border-color:var(--success);color:#fff}.pointage-btn.late-btn.checked{background:var(--warning);border-color:var(--warning);color:#fff}.pointage-btn.absent-btn.checked{background:var(--danger);border-color:var(--danger);color:#fff}.btn-status{border-radius:var(--radius-sm);border:1.5px solid var(--border);background:var(--bg-input);width:32px;height:32px;color:var(--text-secondary);cursor:pointer;transition:var(--transition);justify-content:center;align-items:center;font-family:inherit;font-size:.75rem;font-weight:700;display:flex}.btn-status:hover{opacity:.85}.btn-status.present{border-color:var(--border);color:var(--text-secondary)}.btn-status.present.active{background:var(--success);border-color:var(--success);color:#fff;box-shadow:0 0 8px var(--success)}.btn-status.late{border-color:var(--border);color:var(--text-secondary)}.btn-status.late.active{background:var(--warning);border-color:var(--warning);color:#fff;box-shadow:0 0 8px var(--warning)}.btn-status.absent{border-color:var(--border);color:var(--text-secondary)}.btn-status.absent.active{background:var(--danger);border-color:var(--danger);color:#fff;box-shadow:0 0 8px var(--danger)}.filter-bar{flex-wrap:wrap;align-items:center;gap:10px;margin-bottom:20px;display:flex}.filter-bar select{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;padding:8px 14px;font-family:inherit;font-size:.83rem}.tabs{background:var(--bg-input);border-radius:var(--radius-sm);gap:4px;width:fit-content;margin-bottom:20px;padding:4px;display:flex}.tab{color:var(--text-muted);cursor:pointer;transition:var(--transition);background:0 0;border:none;border-radius:6px;padding:8px 18px;font-family:inherit;font-size:.82rem;font-weight:600}.tab.active{background:var(--accent);color:#fff}.tab:hover:not(.active){color:var(--text-primary)}.progress-bar{background:var(--bg-input);border-radius:3px;height:6px;overflow:hidden}.progress-fill{border-radius:3px;height:100%;transition:width .6s}.toast-container{z-index:300;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:24px;right:24px}.toast{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);box-shadow:var(--shadow-lg);align-items:center;gap:12px;min-width:300px;padding:14px 20px;animation:.3s slideIn;display:flex}.toast.success{border-left:3px solid var(--success)}.toast.error{border-left:3px solid var(--danger)}.toast.warning{border-left:3px solid var(--warning)}@keyframes slideIn{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.empty-state{text-align:center;color:var(--text-muted);padding:60px 20px}.empty-state .icon{opacity:.5;margin-bottom:16px;font-size:3rem}.empty-state h3{color:var(--text-secondary);margin-bottom:8px;font-size:1.1rem}.empty-state p{font-size:.85rem}.mobile-toggle{z-index:150;background:var(--bg-card);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);cursor:pointer;justify-content:center;align-items:center;width:42px;height:42px;font-size:1.2rem;display:none;position:fixed;top:16px;left:16px}.sidebar-date{border-top:1px solid var(--border);color:var(--text-muted);text-align:center;padding:16px 24px;font-size:.78rem}.page-section{display:none}.page-section.active{display:block}@media (width<=1024px){.charts-grid{grid-template-columns:1fr}}@media (width<=768px){.mobile-toggle{display:flex}.sidebar{transform:translate(-100%)}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:60px 16px 16px}.page-header{flex-direction:column;align-items:flex-start}.search-box{width:100%}.form-row{grid-template-columns:1fr}.kpi-grid{grid-template-columns:1fr 1fr}.pointage-grid{grid-template-columns:1fr}}@media (width<=480px){.kpi-grid{grid-template-columns:1fr}}.scanner-container{border-radius:var(--radius-sm);border:2px solid var(--border);width:100%;max-width:400px;margin:0 auto;position:relative;overflow:hidden}.scanner-container img{width:100%;display:block}.scanner-laser{background-color:var(--accent);width:100%;height:2px;box-shadow:0 0 10px 2px var(--accent-glow);z-index:10;position:absolute;top:0;left:0}.scanner-laser.active{animation:2s linear infinite alternate laserScan}@keyframes laserScan{0%{top:0}to{top:100%}}.scanner-overlay{z-index:5;background:#6366f11a;position:absolute;inset:0}.ai-detected{animation:2s highlightRow}@keyframes highlightRow{0%{background-color:var(--accent-glow)}to{background-color:#0000}}
