: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}}.admin-action-dialog-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#000000b3;display:flex;justify-content:center;align-items:center;z-index:1001;animation:fadeIn .3s ease}.admin-action-dialog{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:24px;padding:32px;max-width:500px;width:90%;box-shadow:0 20px 60px #00000080;animation:slideUp .4s ease;color:#fff}.admin-action-dialog-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.admin-action-dialog-header h2{font-size:28px;font-weight:700;margin:0;color:#fff}.admin-action-dialog-header .close-button{background:#fff3;border:none;border-radius:50%;width:40px;height:40px;font-size:28px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s ease;color:#fff;padding:0;line-height:1}.admin-action-dialog-header .close-button:hover{background:#ffffff4d;transform:rotate(90deg)}.admin-action-dialog-subtitle{font-size:18px;color:#ffffffe6;margin:0 0 24px;font-weight:500}.admin-action-dialog-buttons{display:flex;gap:16px;flex-direction:column}.admin-action-button{background:#fff;border:none;border-radius:16px;padding:24px;cursor:pointer;display:flex;align-items:center;gap:16px;transition:all .3s ease;box-shadow:0 4px 12px #0000001a;font-size:20px;font-weight:600}.admin-action-button:hover{transform:translateY(-2px);box-shadow:0 8px 20px #0003}.admin-action-button:active{transform:translateY(0)}.check-in-button{color:#2563eb}.check-in-button:hover{background:#eff6ff}.admin-panel-button{color:#7c3aed}.admin-panel-button:hover{background:#f5f3ff}.button-icon{font-size:32px;flex-shrink:0}.button-text{flex:1;text-align:left;font-size:22px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(50px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:768px){.admin-action-dialog{padding:24px}.admin-action-dialog-header h2{font-size:24px}.admin-action-button{padding:20px}.button-text{font-size:20px}}.scanner-container{position:relative;width:100vw;height:100vh;overflow:hidden;background:#000}.scanner-video{width:100vw!important;height:100vh!important;object-fit:cover!important;position:fixed!important;top:0!important;left:0!important;z-index:1!important;background:#000!important}.scanner-clock-overlay{position:fixed;top:30px;right:30px;z-index:2000;pointer-events:none}.scanner-clock{font-size:64px;font-weight:700;color:#fffffff2;font-family:Courier New,monospace;letter-spacing:3px;text-shadow:0 0 10px rgba(0,0,0,.8),0 0 20px rgba(76,175,80,.5);background:#0006;padding:12px 24px;border-radius:12px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}.scanner-video+div{display:none!important}.qr-scan-overlay{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;z-index:1000!important;pointer-events:none;background:#0009;display:flex!important;align-items:center;justify-content:center;visibility:visible!important;opacity:1!important}.qr-scan-box{position:relative;width:280px;height:280px;background:transparent;box-shadow:0 0 0 9999px #0009;animation:pulse-box 2s ease-in-out infinite;border:3px solid rgba(76,175,80,.8)!important;border-radius:8px;z-index:1001!important}.qr-scan-box.qr-detected{border:3px solid rgba(76,175,80,1)!important;animation:qr-detected-pulse .5s ease-in-out infinite;box-shadow:0 0 0 9999px #0009,0 0 0 5px #4caf50cc,0 0 30px #4caf50e6}@keyframes qr-detected-pulse{0%,to{box-shadow:0 0 0 9999px #0009,0 0 0 5px #4caf50cc,0 0 30px #4caf50e6}50%{box-shadow:0 0 0 9999px #0009,0 0 0 8px #4caf50,0 0 50px #4caf50}}@keyframes pulse-box{0%,to{box-shadow:0 0 0 9999px #0009}50%{box-shadow:0 0 0 9999px #0009}}.qr-scan-box.scanning{animation:pulse-box-scanning .8s ease-in-out infinite}@keyframes pulse-box-scanning{0%,to{box-shadow:0 0 0 9999px #000000b3,0 0 30px #4caf5099}50%{box-shadow:0 0 0 9999px #000000b3,0 0 60px #4caf50e6}}.qr-corner{position:absolute;width:40px;height:40px;border:4px solid rgba(76,175,80,1)!important;animation:corner-pulse 2s ease-in-out infinite;z-index:1002!important;box-shadow:0 0 15px #4caf50cc}.qr-corner-tl{top:-2px;left:-2px;border-right:none;border-bottom:none;border-top-left-radius:12px}.qr-corner-tr{top:-2px;right:-2px;border-left:none;border-bottom:none;border-top-right-radius:12px}.qr-corner-bl{bottom:-2px;left:-2px;border-right:none;border-top:none;border-bottom-left-radius:12px}.qr-corner-br{bottom:-2px;right:-2px;border-left:none;border-top:none;border-bottom-right-radius:12px}@keyframes corner-pulse{0%,to{border-color:#4caf50cc;box-shadow:0 0 10px #4caf5066}50%{border-color:#4caf50;box-shadow:0 0 20px #4caf50cc}}.scanner-idle{position:fixed!important;top:0!important;left:0!important;width:100vw!important;height:100vh!important;background:linear-gradient(135deg,#1a1a2e,#16213e,#0f3460)!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:50!important}.idle-content{text-align:center;animation:fade-in 1s ease-in}.idle-clock{font-size:96px;font-weight:700;color:#fffffff2;font-family:Courier New,monospace;letter-spacing:4px;margin-bottom:40px;text-shadow:0 0 20px rgba(255,255,255,.3);animation:pulse-clock 2s ease-in-out infinite}@keyframes pulse-clock{0%,to{opacity:.95;transform:scale(1)}50%{opacity:1;transform:scale(1.02)}}.idle-logo{font-size:72px;font-weight:900;background:linear-gradient(135deg,#4caf50,#8bc34a);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin-bottom:20px;letter-spacing:8px;text-shadow:0 0 30px rgba(76,175,80,.5)}.idle-subtitle{font-size:28px;color:#fffc;font-weight:300;letter-spacing:4px;margin-bottom:40px}.idle-hint{font-size:18px;color:#ffffff80;font-weight:400;margin-top:30px;animation:pulse-hint 2s ease-in-out infinite}@keyframes fade-in{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.qr-scan-animation-inner{position:absolute;top:0;left:0;width:100%;height:100%;pointer-events:none;z-index:1003!important}.qr-point{position:absolute;width:50px;height:50px;background:radial-gradient(circle,rgba(76,175,80,1) 0%,rgba(76,175,80,.5) 50%,transparent 100%);border-radius:50%;box-shadow:0 0 30px #4caf50,0 0 60px #4caf50cc;animation:scan-point .7s ease-in-out infinite}.qr-point-1{top:10px;left:10px;animation-delay:0s}.qr-point-2{top:10px;right:10px;animation-delay:.2s}.qr-point-3{bottom:10px;left:10px;animation-delay:.4s}.qr-point-4{bottom:10px;right:10px;animation-delay:.6s}@keyframes scan-point{0%,to{transform:scale(1);opacity:1}50%{transform:scale(2.5);opacity:.6;box-shadow:0 0 50px #4caf50,0 0 100px #4caf50e6}}.qr-scan-line{position:absolute;top:0;left:20px;right:20px;height:4px;background:linear-gradient(to right,transparent,rgba(76,175,80,1) 30%,rgba(76,175,80,1) 70%,transparent);box-shadow:0 0 20px #4caf50,0 0 40px #4caf50cc;animation:scan-line 1s ease-in-out infinite}@keyframes scan-line{0%{top:20px;opacity:1}50%{top:calc(100% - 20px);opacity:1}to{top:20px;opacity:1}}.scan-text-overlay{position:absolute;top:calc(50% + 160px);left:50%;transform:translate(-50%);z-index:20;pointer-events:none}.scan-text{color:#fff;font-size:24px;font-weight:600;text-shadow:0 0 10px rgba(76,175,80,.8),0 2px 10px rgba(0,0,0,.5);animation:pulse-scan-text 1s ease-in-out infinite}@keyframes pulse-scan-text{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.qr-hint{position:fixed;top:calc(50% + 160px);left:50%;transform:translate(-50%);background:#000000d9;padding:18px 35px;border-radius:15px;z-index:3000!important;animation:fade-in-hint .5s ease-in;pointer-events:none;box-shadow:0 4px 20px #0006;opacity:0;animation-fill-mode:forwards}.qr-hint p{color:#fff;font-size:22px;font-weight:500;margin:0;text-align:center;animation:pulse-hint 2s ease-in-out infinite .5s;text-shadow:0 2px 10px rgba(0,0,0,.3)}@keyframes fade-in-hint{0%{opacity:0;transform:translate(-50%) translateY(10px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes pulse-hint{0%,to{opacity:1;transform:scale(1)}50%{opacity:.8;transform:scale(1.05)}}.ar-points-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;pointer-events:none;z-index:2000!important}.ar-point{position:fixed;width:20px;height:20px;background:radial-gradient(circle,rgba(76,175,80,1) 0%,rgba(76,175,80,.8) 50%,transparent 100%);border-radius:50%;box-shadow:0 0 20px #4caf50,0 0 40px #4caf50cc,0 0 60px #4caf5099;animation:ar-point-pulse 1s ease-in-out infinite;border:2px solid rgba(76,175,80,1)}@keyframes ar-point-pulse{0%,to{transform:translate(-50%,-50%) scale(1);opacity:1;box-shadow:0 0 20px #4caf50,0 0 40px #4caf50cc,0 0 60px #4caf5099}50%{transform:translate(-50%,-50%) scale(1.5);opacity:.8;box-shadow:0 0 30px #4caf50,0 0 60px #4caf50e6,0 0 90px #4caf50b3}}.scanner-error{position:fixed;bottom:10%;left:50%;transform:translate(-50%);background:#f44336e6;color:#fff;padding:20px 40px;border-radius:12px;z-index:3001!important;max-width:80%;text-align:center;box-shadow:0 4px 20px #f4433666;animation:error-fade-in .3s ease-in;opacity:0;animation-fill-mode:forwards}@keyframes error-fade-in{0%{opacity:0;transform:translate(-50%) translateY(20px)}to{opacity:1;transform:translate(-50%) translateY(0)}}@keyframes error-fade-out{0%{opacity:1;transform:translate(-50%) translateY(0)}to{opacity:0;transform:translate(-50%) translateY(20px)}}.scanner-error.fade-out{animation:error-fade-out .5s ease-out forwards}.scanner-error p{margin:0;font-size:18px;font-weight:500}.scanner-success{position:fixed!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important;background:#4caf50fa!important;color:#fff;padding:50px 60px;border-radius:24px;z-index:10000!important;min-width:350px;max-width:90%;text-align:center;box-shadow:0 8px 32px #4caf5099,0 0 0 9999px #000000b3;animation:success-fade-in .4s ease-out;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px)}@keyframes success-fade-in{0%{opacity:0;transform:translate(-50%,-50%) scale(.9)}to{opacity:1;transform:translate(-50%,-50%) scale(1)}}.success-content{display:flex;flex-direction:column;align-items:center;gap:20px}.success-title{margin:0 0 10px!important;font-size:48px!important;font-weight:800!important;line-height:1.2}.success-employee-name{font-size:32px!important;font-weight:700!important;color:#fff!important;margin:10px 0!important;text-align:center;opacity:.98}.success-message{margin:15px 0 0!important;font-size:22px!important;font-weight:500!important;opacity:.95}.success-time{margin-top:15px!important;font-size:24px!important;font-weight:600!important;opacity:.9;font-family:Courier New,monospace;letter-spacing:1px;padding:8px 16px;background:#ffffff26;border-radius:8px}.success-content h3{margin:0 0 20px;font-size:32px;font-weight:700}.success-content p{margin:10px 0;font-size:18px;font-weight:400}.success-status{margin-top:20px!important;font-size:16px!important;opacity:.9}.scanner-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:#000c;display:flex;align-items:center;justify-content:center;z-index:5}.scanner-placeholder{text-align:center;color:#fff;font-size:20px;padding:40px}.scanner-placeholder p{margin:0;animation:pulse-hint 2s ease-in-out infinite}@media(max-width:768px){.idle-clock{font-size:72px;margin-bottom:30px}.idle-logo{font-size:56px}.idle-subtitle{font-size:22px}.idle-hint{font-size:16px}.scanner-clock{font-size:48px;padding:10px 20px}.scanner-clock-overlay{top:20px;right:20px}.qr-scan-box{width:250px;height:250px}.qr-hint{top:calc(50% + 145px)}.qr-hint p{font-size:18px}.scan-text-overlay{top:calc(50% + 145px)}.success-title{font-size:40px!important}.success-employee-name{font-size:28px!important}.success-message,.success-time{font-size:20px!important}}@media(max-width:480px){.idle-logo{font-size:48px}.idle-subtitle{font-size:18px}.idle-hint{font-size:14px}.qr-scan-box{width:220px;height:220px}.qr-hint{top:calc(50% + 130px)}.qr-hint p{font-size:16px}.scan-text-overlay{top:calc(50% + 130px)}}.numeric-keyboard-overlay{position:fixed;inset:0;background:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.numeric-keyboard-container{background:#fff;border-radius:20px;padding:30px;max-width:500px;width:100%;box-shadow:0 10px 40px #0000004d}.numeric-keyboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.numeric-keyboard-header h2{margin:0;color:#333;font-size:24px}.close-button{background:transparent;border:none;font-size:32px;color:#666;cursor:pointer;padding:0;width:40px;height:40px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .3s}.close-button:hover{background:#f5f5f5;color:#333}.code-input-container{margin-bottom:30px}.code-dots{display:flex;justify-content:center;gap:15px;margin-bottom:20px}.code-dot{width:50px;height:50px;border:3px solid #e0e0e0;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;color:#e0e0e0;transition:all .3s;background:#fff}.code-dot.filled{border-color:#667eea;color:#667eea;background:#f0f4ff}.code-dot.loading{animation:pulse 1s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.code-error{text-align:center;color:#f44336;font-size:14px;margin-top:10px}.code-error p{margin:0}.numeric-keyboard{display:flex;flex-direction:column;gap:15px}.keyboard-row{display:flex;gap:15px;justify-content:center}.keyboard-key{flex:1;min-width:80px;height:80px;border:2px solid #e0e0e0;border-radius:12px;background:#fff;font-size:28px;font-weight:600;color:#333;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.keyboard-key:hover:not(:disabled){background:#f5f5f5;border-color:#667eea;transform:scale(1.05)}.keyboard-key:active:not(:disabled){transform:scale(.95)}.keyboard-key:disabled{opacity:.5;cursor:not-allowed}.keyboard-key-clear{font-size:16px;background:#fff3e0;border-color:#ff9800;color:#ff9800}.keyboard-key-backspace{font-size:24px;background:#ffebee;border-color:#f44336;color:#f44336}.keyboard-loading{text-align:center;margin-top:20px;color:#666;font-size:16px}@media(max-width:768px){.numeric-keyboard-container{padding:20px;max-width:100%}.numeric-keyboard-header h2{font-size:20px}.code-dot{width:40px;height:40px;font-size:20px}.keyboard-key{min-width:70px;height:70px;font-size:24px}.keyboard-key-clear{font-size:14px}}@media(min-width:769px)and (max-width:1024px){.numeric-keyboard-container{max-width:600px}.code-dot{width:45px;height:45px}.keyboard-key{min-width:75px;height:75px}}@media(min-width:1025px){.numeric-keyboard-container{max-width:700px;padding:40px}.code-dot{width:60px;height:60px;font-size:28px}.keyboard-key{min-width:100px;height:100px;font-size:32px}}.scanner-page{width:100%;min-height:100vh;background:#000;padding:0;margin:0;overflow:hidden}.scanner-wrapper{width:100%;height:100vh;margin:0;padding:0}.scanner-warning{width:100%;max-width:600px;margin:50px auto;padding:30px;background:#fff;border-radius:8px;box-shadow:0 4px 6px #0000001a;text-align:center}.scanner-warning h2{color:#f44336;margin-bottom:15px;font-size:24px}.scanner-warning p{margin:10px 0;color:#666;font-size:16px}.device-info{margin:20px 0;padding:20px;background:#ffffff1a;border-radius:12px;border:2px solid rgba(255,193,7,.5)}.device-id-display{font-family:Courier New,monospace;font-size:18px;font-weight:700;color:#ffc107;background:#0000004d;padding:12px 20px;border-radius:8px;margin:10px 0;word-break:break-all;text-align:center;letter-spacing:1px}.device-id-hint{font-size:14px;color:#ffffffb3;margin-top:10px;text-align:center}.registration-status{margin-top:20px;padding:15px;background:#2196f333;border-radius:8px;border:1px solid rgba(33,150,243,.5);text-align:center}.registration-status p{margin:0;color:#2196f3;font-size:16px}@media(max-width:768px){.scanner-warning{margin:20px;padding:20px}.scanner-warning h2{font-size:20px}.scanner-warning p{font-size:14px}}@media(min-width:769px)and (max-width:1024px){.scanner-warning{max-width:700px}}@media(min-width:1025px){.scanner-warning{max-width:800px}}.event-list{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.event-list-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.event-list-header h2{margin:0;color:#333}.refresh-button:hover{background:#5568d3}.event-filters{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px;padding:15px;background:#f9f9f9;border-radius:8px}.filter-group{display:flex;flex-direction:column}.filter-group label{margin-bottom:5px;font-size:14px;color:#666;font-weight:500}.filter-group input,.filter-group select{padding:8px;border:1px solid #ddd;border-radius:6px;font-size:14px}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#667eea}.loading,.empty-state{text-align:center;padding:40px;color:#666}.event-table{overflow-x:auto;margin-bottom:20px}.event-table table{width:100%;border-collapse:collapse}.event-table th{background:#f5f5f5;padding:12px;text-align:left;font-weight:600;color:#1a1a1a;border-bottom:2px solid #e0e0e0;font-size:14px}.event-table td{padding:12px;border-bottom:1px solid #f0f0f0;color:#212121;font-size:14px}.event-row:hover{background:#f9f9f9}.event-row.manual-event{background:#fff9e6}.event-row.manual-event td{color:#212121}.event-row.sync-failed{background:#ffe6e6}.event-row.sync-failed td{color:#212121}.event-row.synced{background:#f0f9f0}.event-row.synced td{color:#212121}.event-type{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:600}.event-type-check_in{background:#e6f7e6;color:#2d7a2d}.event-type-check_out{background:#ffe6e6;color:#7a2d2d}.status-badge{display:inline-block;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-badge.synced{background:#e6f7e6;color:#2d7a2d}.status-badge.pending{background:#fff4e6;color:#7a5a2d}.status-badge.failed{background:#ffe6e6;color:#7a2d2d}.event-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;padding:15px;background:#f9f9f9;border-radius:8px}.event-stats p{margin:0;color:#666}.event-stats strong{color:#333}@media(max-width:768px){.event-filters{grid-template-columns:1fr}.event-table{font-size:12px}.event-table th,.event-table td{padding:8px}.event-stats{grid-template-columns:1fr}}.manual-check-form{display:flex;justify-content:center;padding:20px}.form-card{background:#fff;border-radius:12px;padding:30px;max-width:500px;width:100%;box-shadow:0 2px 8px #0000001a}.form-card h2{margin:0 0 10px;color:#333}.form-hint{color:#666;font-size:14px;margin:0 0 25px}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;color:#333;font-weight:500}.form-group input,.form-group select{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;font-size:16px;transition:border-color .3s}.form-group input:focus,.form-group select:focus{outline:none;border-color:#667eea}.form-group input:disabled,.form-group select:disabled{background-color:#f5f5f5;cursor:not-allowed}.form-group small{display:block;margin-top:5px;color:#999;font-size:12px}.form-error{background-color:#fee;border:1px solid #fcc;border-radius:8px;padding:12px;margin-bottom:20px}.form-error p{margin:0;color:#c33;font-size:14px}.form-success{background-color:#efe;border:1px solid #cfc;border-radius:8px;padding:12px;margin-bottom:20px}.form-success p{margin:0;color:#3c3;font-size:14px}.form-card button{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .3s}.form-card button:hover:not(:disabled){opacity:.9}.form-card button:disabled{opacity:.6;cursor:not-allowed}.employee-select-container{position:relative}.employee-select-display{width:100%;padding:12px;border:2px solid #e0e0e0;border-radius:8px;background:#fff;cursor:pointer;display:flex;justify-content:space-between;align-items:center;min-height:46px;transition:border-color .3s}.employee-select-display:hover{border-color:#667eea}.employee-select-display .placeholder{color:#999}.selected-employee{flex:1}.employee-name{font-weight:600;color:#333;margin-bottom:2px}.employee-details{font-size:12px;color:#666}.dropdown-arrow{color:#999;font-size:12px;margin-left:8px}.employee-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:#fff;border:2px solid #667eea;border-radius:8px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:400px;display:flex;flex-direction:column}.dropdown-search{padding:12px;border-bottom:1px solid #e0e0e0}.dropdown-search input{width:100%;padding:10px;border:1px solid #e0e0e0;border-radius:6px;font-size:14px}.dropdown-search input:focus{outline:none;border-color:#667eea}.dropdown-list{overflow-y:auto;max-height:320px}.dropdown-item{padding:12px 16px;cursor:pointer;transition:background-color .2s;border-bottom:1px solid #f0f0f0}.dropdown-item:last-child{border-bottom:none}.dropdown-item:hover{background-color:#f5f7ff}.dropdown-item .employee-name{font-weight:500;color:#333;margin-bottom:4px}.dropdown-item .employee-details{font-size:12px;color:#666}.dropdown-item-empty{padding:20px;text-align:center;color:#999;font-size:14px}.charts{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.charts-loading{text-align:center;padding:40px;color:#666}.charts-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px;flex-wrap:wrap;gap:15px}.charts-header h2{margin:0;color:#333}.date-selector{display:flex;align-items:center;gap:10px}.date-selector label{color:#666;font-weight:500}.date-selector input{padding:8px;border:2px solid #e0e0e0;border-radius:8px;font-size:14px}.date-selector input:focus{outline:none;border-color:#667eea}.charts-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px;margin-bottom:20px}.chart-card{background:#f9f9f9;border-radius:8px;padding:20px}.chart-card h3{margin:0 0 15px;color:#333;font-size:18px}.chart-container{height:300px;overflow-x:auto}.chart-bars{display:flex;align-items:flex-end;height:100%;gap:4px;padding:10px 0}.chart-bar-group{flex:1;display:flex;flex-direction:column;align-items:center;min-width:30px}.chart-bar-wrapper{width:100%;height:100%;display:flex;align-items:flex-end;justify-content:center;gap:2px;position:relative}.chart-bar{width:100%;background:linear-gradient(180deg,#667eea,#764ba2);border-radius:4px 4px 0 0;position:relative;transition:opacity .3s;min-height:20px;display:flex;align-items:flex-end;justify-content:center;padding-bottom:4px}.chart-bar:hover{opacity:.8}.chart-bar-in{background:linear-gradient(180deg,#4caf50,#45a049)}.chart-bar-out{background:linear-gradient(180deg,#f44336,#d32f2f)}.chart-bar-value{color:#fff;font-size:10px;font-weight:600;text-shadow:0 1px 2px rgba(0,0,0,.3)}.chart-bar-label{margin-top:5px;font-size:10px;color:#666;text-align:center}.charts-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.stat-card{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border-radius:8px;padding:20px;text-align:center}.stat-value{font-size:32px;font-weight:700;margin-bottom:5px}.stat-label{font-size:14px;opacity:.9}@media(max-width:768px){.charts-grid{grid-template-columns:1fr}.chart-container{height:200px}.chart-bar-label{font-size:8px}}.sync-status{background:#fff;border-radius:12px;padding:20px;box-shadow:0 2px 8px #0000001a}.sync-status-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.sync-status-header h2{margin:0;color:#333}.refresh-button{background:#667eea;color:#fff;border:none;padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;transition:background .3s}.refresh-button:hover:not(:disabled){background:#5568d3}.refresh-button:disabled{opacity:.6;cursor:not-allowed}.sync-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:15px;margin-bottom:20px}.stat-card{background:#f9f9f9;border-radius:8px;padding:20px;text-align:center;border:2px solid transparent;transition:all .3s}.stat-card.success{border-color:#4caf50;background:#e8f5e9}.stat-card.warning{border-color:#ff9800;background:#fff3e0}.stat-card.error{border-color:#f44336;background:#ffebee}.stat-card.info{border-color:#2196f3;background:#e3f2fd}.stat-icon{font-size:32px;margin-bottom:10px}.stat-value{font-size:24px;font-weight:700;color:#333;margin-bottom:5px}.stat-label{font-size:14px;color:#666}.sync-actions{display:flex;gap:15px;margin-bottom:20px;flex-wrap:wrap}.sync-button,.retry-button{flex:1;min-width:200px;padding:14px;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .3s}.sync-button{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.sync-button:hover:not(:disabled){opacity:.9}.retry-button{background:#ff9800;color:#fff}.retry-button:hover:not(:disabled){opacity:.9}.sync-button:disabled,.retry-button:disabled{opacity:.6;cursor:not-allowed}.sync-errors{background:#ffebee;border:1px solid #f44336;border-radius:8px;padding:15px;margin-bottom:20px}.sync-errors h3{margin:0 0 10px;color:#c62828;font-size:16px}.sync-errors ul{margin:0;padding-left:20px}.sync-errors li{color:#666;font-size:14px;margin-bottom:5px}.sync-info{background:#f9f9f9;border-radius:8px;padding:15px}.sync-info p{margin:5px 0;color:#666;font-size:14px}.sync-info strong{color:#333}.sync-info .online{color:#4caf50;font-weight:600}.sync-info .offline{color:#f44336;font-weight:600}@media(max-width:768px){.sync-stats{grid-template-columns:1fr}.sync-actions{flex-direction:column}.sync-button,.retry-button{width:100%}}.admin-page{min-height:100vh;background:#f5f5f5}.admin-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:20px;display:flex;justify-content:space-between;align-items:center;box-shadow:0 2px 10px #0000001a}.admin-header h1{margin:0;font-size:24px}.logout-button{background:#fff3;color:#fff;border:1px solid rgba(255,255,255,.3);padding:8px 16px;border-radius:8px;cursor:pointer;font-size:14px;transition:background .3s}.logout-button:hover{background:#ffffff4d}.admin-tabs{display:flex;background:#fff;border-bottom:2px solid #e0e0e0;overflow-x:auto}.admin-tabs button{flex:1;padding:16px;border:none;background:transparent;cursor:pointer;font-size:16px;color:#666;border-bottom:3px solid transparent;transition:all .3s;white-space:nowrap}.admin-tabs button:hover{background:#f9f9f9;color:#333}.admin-tabs button.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.admin-content{padding:20px;max-width:1200px;margin:0 auto}@media(max-width:768px){.admin-header{flex-direction:column;gap:15px}.admin-tabs{flex-wrap:wrap}.admin-tabs button{min-width:50%}.admin-content{padding:15px}}.update-notification{position:fixed;top:0;left:0;right:0;z-index:10000;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;padding:16px;box-shadow:0 4px 12px #00000026;animation:slideDown .3s ease-out}@keyframes slideDown{0%{transform:translateY(-100%)}to{transform:translateY(0)}}.update-notification__content{max-width:1200px;margin:0 auto;display:flex;align-items:center;justify-content:center;gap:16px;flex-wrap:wrap}.update-notification__icon{font-size:24px;animation:rotate 2s linear infinite}.update-notification__spinner{width:20px;height:20px;border:3px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.update-notification__button{padding:8px 16px;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s}.update-notification__button--primary{background:#fff;color:#667eea}.update-notification__button--primary:hover{background:#f0f0f0;transform:translateY(-1px);box-shadow:0 2px 8px #0003}.update-notification__button--secondary{background:#fff3;color:#fff}.update-notification__button--secondary:hover{background:#ffffff4d}@media(max-width:640px){.update-notification__content{font-size:14px;gap:12px}.update-notification__button{padding:6px 12px;font-size:13px}}.network-status{position:fixed;top:0;left:0;right:0;z-index:9999;padding:12px;box-shadow:0 2px 8px #00000026;animation:slideDownFade .3s ease-out;font-size:14px}@keyframes slideDownFade{0%{transform:translateY(-100%);opacity:0}to{transform:translateY(0);opacity:1}}.network-status--offline{background:linear-gradient(135deg,#ef4444,#dc2626);color:#fff}.network-status--checking{background:linear-gradient(135deg,#f59e0b,#d97706);color:#fff}.network-status--online{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.network-status__content{max-width:1200px;margin:0 auto;display:flex;align-items:center;gap:12px}.network-status__icon{font-size:24px;flex-shrink:0}.network-status--checking .network-status__icon{animation:rotate 2s linear infinite}@keyframes rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.network-status__text{flex:1}.network-status__message{font-weight:600;font-size:15px;margin-bottom:2px}.network-status__submessage{font-size:13px;opacity:.9}@media(max-width:640px){.network-status{padding:10px;font-size:13px}.network-status__icon{font-size:20px}.network-status__message{font-size:14px}.network-status__submessage{font-size:12px}}*{margin:0;padding:0;box-sizing:border-box}html,body{width:100%;height:100%;overflow:hidden}#root{width:100%;height:100vh;margin:0;padding:0}body{margin:0;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}
