@charset "UTF-8";.vendor-welcome{max-width:800px;margin:2rem auto;padding:2rem;background:linear-gradient(135deg,rgba(102,126,234,.1),rgba(118,75,162,.1));border-radius:16px;border:1px solid rgba(102,126,234,.2);box-shadow:0 8px 32px #0000001a}.vendor-welcome-header{display:flex;align-items:center;gap:1rem;margin-bottom:2rem;text-align:center}.vendor-welcome-header h2{color:#667eea;margin:0;font-size:1.75rem;font-weight:600}.vendor-icon{color:#667eea;background:rgba(102,126,234,.1);padding:.5rem;border-radius:50%;flex-shrink:0}.vendor-info-card{background:white;border-radius:12px;padding:1.5rem;margin-bottom:2rem;box-shadow:0 4px 16px #0000000d;border:1px solid rgba(102,126,234,.1)}.info-item{display:flex;align-items:flex-start;gap:.75rem;margin-bottom:1rem}.info-item:last-child{margin-bottom:0}.info-icon{color:#667eea;margin-top:2px;flex-shrink:0}.info-item p{margin:0;color:#374151;line-height:1.5}.info-item strong{color:#667eea;font-weight:600}.vendor-actions{display:flex;justify-content:center;gap:1rem}.action-button{display:inline-flex;align-items:center;gap:.5rem;padding:.75rem 1.5rem;border-radius:8px;text-decoration:none;font-weight:500;transition:all .3s ease;border:none;cursor:pointer;font-size:1rem}.action-button.primary{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;box-shadow:0 4px 16px #667eea4d}.action-button.primary:hover{transform:translateY(-2px);box-shadow:0 6px 20px #667eea66}@media (max-width: 768px){.vendor-welcome{margin:1rem;padding:1.5rem}.vendor-welcome-header{flex-direction:column;text-align:center}.vendor-welcome-header h2{font-size:1.5rem}.vendor-info-card{padding:1rem}.action-button{width:100%;justify-content:center}}.dashboard-page{height:calc(100vh - 50px);width:100%;background:#ffffff;padding:0;margin:0;overflow:hidden}.dashboard-container{width:100%;height:100%;margin:0;padding:0;display:flex;flex-direction:column;overflow:hidden}.dashboard-header{display:flex;justify-content:space-between;align-items:center;background:white;padding:24px 32px;border-radius:16px;box-shadow:0 4px 12px #0000001a;border:1px solid #e2e8f0}.header-title{display:flex;align-items:center;gap:12px}.title-icon{color:#3b82f6}.header-title h1{margin:0;font-size:28px;font-weight:700;color:#1e293b}.header-info{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.welcome-text{font-size:16px;font-weight:600;color:#374151}.user-role{font-size:14px;color:#6b7280;padding:4px 12px;background:#f3f4f6;border-radius:20px}.quick-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px}.stat-card{background:white;padding:24px;border-radius:12px;box-shadow:0 2px 8px #00000014;border:1px solid #e2e8f0;display:flex;align-items:center;gap:16px;transition:transform .2s ease,box-shadow .2s ease}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 16px #0000001f}.stat-icon{padding:12px;border-radius:12px;background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;display:flex;align-items:center;justify-content:center}.stat-content{flex:1}.stat-value{font-size:28px;font-weight:700;color:#1e293b;line-height:1;margin-bottom:4px}.stat-label{font-size:14px;color:#6b7280;font-weight:500}.dashboard-content{flex:1;height:100%;width:100%;overflow:hidden}.dashboard-panel{background:white;border-radius:0;box-shadow:none;border:none;overflow:hidden;height:100%;width:100%;display:flex;flex-direction:column;flex-shrink:0}.panel-header{padding:8px 16px;border-bottom:1px solid #e2e8f0;display:flex;justify-content:space-between;align-items:center;background:#f8fafc;min-height:50px}.panel-header h2{margin:0;font-size:20px;font-weight:600;color:#1e293b}.panel-controls{display:flex;gap:8px}.control-btn{padding:8px 12px;border:1px solid #d1d5db;background:white;border-radius:8px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;color:#6b7280}.control-btn:hover:not(:disabled){background:#f3f4f6;border-color:#9ca3af;color:#374151}.control-btn:disabled{opacity:.5;cursor:not-allowed}.refresh-btn .spinning{animation:spin 1s linear infinite}.dashboard-iframe.loading{opacity:0}.iframe-loading{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:white;z-index:10}.loading-spinner{width:40px;height:40px;border:3px solid #e2e8f0;border-top:3px solid #3b82f6;border-radius:50%;animation:spin 1s linear infinite;margin-bottom:16px}.iframe-loading p{color:#6b7280;font-size:16px;margin:0}.iframe-placeholder{position:absolute;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;background:white;z-index:5}.placeholder-content{text-align:center;max-width:600px;padding:40px}.placeholder-icon{color:#9ca3af;margin-bottom:24px}.placeholder-content h3{font-size:24px;font-weight:600;color:#1e293b;margin:0 0 16px}.placeholder-content p{color:#6b7280;font-size:16px;margin-bottom:24px;line-height:1.6}.placeholder-content ol{text-align:left;color:#374151;font-size:14px;line-height:1.6;margin-bottom:24px}.placeholder-content li{margin-bottom:8px}.placeholder-content code{background:#f3f4f6;padding:2px 6px;border-radius:4px;font-family:Courier New,monospace;font-size:13px;color:#dc2626}.placeholder-note{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;padding:16px;text-align:left;font-size:14px;color:#92400e}.placeholder-note strong{color:#78350f}.dashboard-footer{text-align:center;padding:16px;color:#6b7280;font-size:14px}@media (max-width: 768px){.dashboard-page{padding:16px}.dashboard-header{flex-direction:column;gap:16px;text-align:center;padding:20px}.header-info{align-items:center}.quick-stats{grid-template-columns:1fr}.stat-card{padding:20px}.panel-header{padding:16px 20px;flex-direction:column;gap:12px}.dashboard-content.fullscreen{padding:12px}.placeholder-content{padding:24px 20px}.placeholder-content h3{font-size:20px}}@media (max-width: 480px){.header-title h1{font-size:22px}.stat-value{font-size:24px}.dashboard-panel{min-height:500px}}.dashboard-content,.stat-card,.control-btn{transition:all .2s ease}.control-btn:focus,.dashboard-iframe:focus{outline:2px solid #3b82f6;outline-offset:2px}.lego-reporting-view .embedding-footer{display:none!important;visibility:hidden!important;height:0!important;z-index:-1!important}.embedding-footer{display:none!important;visibility:hidden!important;height:0!important;overflow:hidden!important}.embedding-footer.layout-align-end-end.layout-row.show-navigation{display:none!important;visibility:hidden!important;height:0!important;max-height:0!important}[class*=embedding-footer]{display:none!important;visibility:hidden!important;height:0!important}[class*=show-navigation]{display:none!important;visibility:hidden!important}.iframe-container{flex:1;position:relative;background:#ffffff;height:calc(100% + 60px);width:100%;overflow:hidden;margin-bottom:-60px}.dashboard-iframe{width:100%;height:100%;border:none;transition:opacity .3s ease;display:block;margin:0;padding:0}.iframe-container .footer-overlay{position:absolute;bottom:0;left:0;right:0;height:50px;background:white;pointer-events:none;z-index:10;display:none}*{box-sizing:border-box}html,body{margin:0;padding:0;width:100%;height:100%;overflow-x:hidden}html body{font-family:Times New Roman,Times,serif!important}.printcard-page body,bo.preview-wrap{width:600px!important;min-width:320px!important;max-width:600px!important;flex-shrink:0!important;display:flex!important;flex-direction:column!important;background:#fafafa!important;border-left:1px solid #e0e0e0!important;margin:0!important;padding:0!important;position:relative!important;height:calc(100vh - 50px)!important;font-family:Times New Roman,Times,serif!important}age,html body .printcard-page{font-family:Times New Roman,Times,serif!important}#root{width:100%;height:100vh;margin:0;padding:0}.printcard-page-wrapper .container,.printcard-page-wrapper .container-fluid,.printcard-page-wrapper .container-sm,.printcard-page-wrapper .container-md,.printcard-page-wrapper .container-lg,.printcard-page-wrapper .container-xl,.printcard-page-wrapper .container-xxl{max-width:none;width:100%;margin:0;padding:0}.row{margin:0!important;padding:0!important}.col,.col-1,.col-2,.col-3,.col-4,.col-5,.col-6,.col-7,.col-8,.col-9,.col-10,.col-11,.col-12{padding:0!important;margin:0!important}.printcard-page-wrapper .shell *{max-width:none}.printcard-page-wrapper .shell .container,.printcard-page-wrapper .shell .container-fluid{max-width:none;width:100%;margin:0;padding:0}.printcard-page-wrapper .printcard-page{width:100%;height:100%;overflow:hidden;font-family:Times New Roman,Times,serif!important}.printcard-page-wrapper .printcard-page,.printcard-page *{font-family:Times New Roman,Times,serif!important}.printcard-page-wrapper .shell{display:flex!important;height:calc(100vh - 50px)!important;width:100%!important;background:#f5f5f5!important;overflow:hidden!important;margin:0!important;padding:0!important;position:relative!important}.printcard-page-wrapper .left{flex:1!important;display:flex!important;flex-direction:column!important;background:#fff!important;min-width:0!important;margin:0!important;padding:0!important;width:calc(100% - 600px)!important}.printcard-page-wrapper .right{width:400px;display:flex;flex-direction:column;background:#fafafa}.printcard-page-wrapper .pane{display:flex;flex-direction:column;height:100%}.pane.list{flex:1;display:flex;flex-direction:column;height:100%}.printcard-page-wrapper .pane-title{padding:0 16px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-bottom:1px solid #e0e0e0;font-weight:600;font-size:16px;height:50px;display:flex;gap:12px;align-items:center;justify-content:space-between;flex-shrink:0;box-sizing:border-box}.printcard-page-wrapper .title-left{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.printcard-page-wrapper .title-right{display:flex;align-items:center;gap:12px;flex-shrink:0}.title-left label{display:flex;align-items:center;gap:6px;font-size:14px;cursor:pointer;white-space:nowrap}.title-left input[type=checkbox]{margin:0;cursor:pointer}.title-left input[type=text]{padding:8px 12px;border:1px solid rgba(255,255,255,.3);border-radius:6px;background:rgba(255,255,255,.1);color:#fff;font-size:14px;flex:1;min-width:200px;max-width:none}.title-left input[type=text]::-moz-placeholder{color:#ffffffb3}.title-left input[type=text]::placeholder{color:#ffffffb3}.title-left input[type=text]:focus{outline:none;background:rgba(255,255,255,.2);border-color:#ffffff80}.title-left button{padding:8px 16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease}.title-left button:hover{background:rgba(255,255,255,.2);border-color:#ffffff80}.title-left button:disabled{opacity:.5;cursor:not-allowed}.title-right button{padding:8px 16px;background:rgba(255,255,255,.1);border:1px solid rgba(255,255,255,.3);color:#fff;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;white-space:nowrap}.title-right button:hover{background:rgba(255,255,255,.2);border-color:#ffffff80}.title-right button:disabled{opacity:.5;cursor:not-allowed}.printcard-page-wrapper .table-wrap{flex:1;overflow:auto;background:white;width:100%;min-width:0;height:calc(100vh - 150px);position:relative}.printcard-page-wrapper .grid{width:100%;min-width:100%;border-collapse:collapse;font-size:14px;table-layout:auto}.grid th{background:#f8f9fa;border-bottom:2px solid #e9ecef;padding:0;position:sticky;top:0;z-index:10;vertical-align:middle;min-width:80px}.grid th:first-child{min-width:36px;max-width:36px;width:36px}.grid th span{display:block;padding:12px 8px;font-weight:600;color:#495057;text-align:left}.printcard-page-wrapper .th-cell{display:flex;align-items:center;justify-content:space-between;padding:8px 12px;min-height:48px;white-space:nowrap;position:relative}.th-cell span{flex:1;text-align:center;font-weight:600;color:#495057;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:calc(100% - 24px)}.printcard-page-wrapper .filter-btn{background:lavender;border:none;cursor:pointer;padding:4px 6px;color:#6c757d;font-size:12px;line-height:1;border-radius:3px;transition:all .2s ease;flex-shrink:0;margin-left:4px}.filter-btn:hover{background:rgba(108,117,125,.1);color:#495057}.filter-btn:focus{outline:none;background:rgba(108,117,125,.15)}.printcard-page-wrapper .filter-menu{position:absolute;top:100%;right:0;background:white;border:1px solid #e9ecef;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:300px;max-width:500px;padding:12px;display:none}.th-cell:first-child .filter-menu{right:auto;left:0}.th-cell:last-child .filter-menu{right:0;left:auto;transform:translate(0)}.th-cell:nth-last-child(-n+2) .filter-menu{right:0;max-width:280px}.filter-menu.show{display:block;max-height:80vh;overflow:visible}.printcard-page-wrapper .filter-search{width:100%;padding:8px 12px;border:1px solid #e9ecef;border-radius:4px;font-size:13px;margin-bottom:8px}.filter-search:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 2px #667eea1a}.printcard-page-wrapper .filter-options{max-height:calc(70vh - 120px);overflow-y:auto;border:1px solid #e9ecef;border-radius:4px;margin-bottom:12px}.printcard-page-wrapper .filter-option{display:flex;align-items:center;padding:6px 10px;font-size:13px;cursor:pointer;border-bottom:1px solid #f8f9fa}.filter-option input[type=checkbox]{margin-right:8px}.printcard-page-wrapper .filter-option-text{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;text-align:left!important}.printcard-page-wrapper .filter-option-count{color:#6c757d;font-size:11px;margin-left:4px;flex-shrink:0;text-align:right!important;min-width:30px;padding-left:8px}.printcard-page-wrapper .filter-actions{display:flex;gap:8px;justify-content:flex-end}.filter-actions button{padding:6px 12px;border:1px solid #e9ecef;background:white;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease}.filter-actions button:first-child{background:#667eea;color:#fff;border-color:#667eea}.filter-actions button:first-child:hover{background:#5a6fd8;border-color:#5a6fd8}.filter-actions button:last-child:hover{background:#f8f9fa}.printcard-page-wrapper .select-all-option{background:#f8f9fa;font-weight:500;border-bottom:2px solid #e9ecef!important}@media (max-width: 1400px){.th-cell span{font-size:12px}.printcard-page-wrapper .filter-btn{font-size:10px;padding:2px 4px}}@media (max-width: 1200px){.printcard-page-wrapper .th-cell{padding:6px 8px;min-height:40px}.th-cell span{font-size:11px}.printcard-page-wrapper .filter-menu{min-width:200px}}@media (max-width: 1024px){.printcard-page-wrapper .th-cell{padding:4px 6px;min-height:36px}.th-cell span{font-size:10px}.printcard-page-wrapper .filter-btn{padding:1px 3px}.printcard-page-wrapper .filter-menu{min-width:180px;max-width:250px}.printcard-page-wrapper .filter-menu{right:auto!important;left:0!important;transform:none!important}}.grid td{padding:2px 5px;text-align:center;border-bottom:1px solid #e9ecef;vertical-align:middle}.grid tr:hover{background:#4d8ec4}.grid tr.selected{background:#3fc56c!important}.grid tr.selected:hover{background:#4d8ec4!important}.printcard-page-wrapper .menu-actions{display:flex;gap:8px}.menu-actions button{flex:1;padding:6px 12px;border:1px solid #e9ecef;background:white;border-radius:4px;cursor:pointer;font-size:12px;transition:all .2s ease}.menu-actions button:first-child{background:#667eea;color:#fff;border-color:#667eea}.menu-actions button:first-child:hover{background:#5a6fd8}.menu-actions button:last-child:hover{background:#f8f9fa}.printcard-page-wrapper .cell-person{display:flex;align-items:center;gap:12px}.printcard-page-wrapper .thumb{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #e9ecef}.printcard-page-wrapper .meta{flex:1}.printcard-page-wrapper .name{font-weight:500;color:#333;margin-bottom:2px}.printcard-page-wrapper .sub{font-size:12px;color:#6c757d}.printcard-page-wrapper .pane-footer{padding:12px 16px;background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;align-items:center;justify-content:space-between;gap:16px;height:50px;flex-shrink:0;box-sizing:border-box;min-width:0}.printcard-page-wrapper .footer-left,.printcard-page-wrapper .footer-right{flex:0 0 auto;white-space:nowrap;font-size:13px}.printcard-page-wrapper .footer-center{flex:1;display:flex;justify-content:center;min-width:0}.printcard-page-wrapper .pagination{display:flex;justify-content:center;align-items:center;gap:10px;background:transparent;position:static;border:none;box-shadow:none;border-radius:0;padding:0;height:auto;z-index:auto;flex-shrink:0}.printcard-page-wrapper .pagination button{padding:8px 16px;border:1px solid #667eea;background:white;cursor:pointer;border-radius:6px;font-size:14px;font-weight:600;color:#667eea;transition:all .3s ease;min-width:70px;position:relative;z-index:101;pointer-events:auto;-webkit-user-select:none;-moz-user-select:none;user-select:none;display:flex;align-items:center;justify-content:center}.printcard-page-wrapper .pagination button:enabled:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.printcard-page-wrapper .pagination button:disabled{opacity:.4;cursor:not-allowed;background:#f8f9fa!important;color:#6c757d!important;border-color:#dee2e6!important;pointer-events:none;transform:none!important;box-shadow:none!important}.printcard-page-wrapper #pageInfo{font-size:14px;font-weight:600;color:#333;background:#f8f9fa;border-radius:6px;padding:8px 16px;white-space:nowrap}.printcard-page-wrapper .preview-wrap{width:560px!important;min-width:320px!important;max-width:600px!important;flex-shrink:0!important;display:flex!important;flex-direction:column!important;background:#fafafa!important;border-left:1px solid #e0e0e0!important;margin:0!important;padding:0!important;position:relative!important;height:100vh!important;font-family:Times New Roman,Times,serif!important}.printcard-page-wrapper .preview-header{padding:0 12px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border-bottom:1px solid #e0e0e0;height:50px;display:flex;align-items:center;flex-shrink:0;box-sizing:border-box;font-family:Times New Roman,Times,serif!important}.preview-header>div{display:flex;flex-direction:row;gap:12px;align-items:center;width:100%;justify-content:space-between}.printcard-page-wrapper .selected-count{color:#000;font-size:12px;text-align:center;flex:1}.selected-count span{font-size:18px;font-weight:700;color:#3700ff}.printcard-page-wrapper .selected-table-controls{display:flex;flex-direction:row;gap:8px}.selected-table-controls button{padding:6px 12px;background:#6c757d;color:#fff;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-size:11px;font-family:inherit!important;transition:all .2s ease;width:auto;min-width:100px;white-space:nowrap}.selected-table-controls button:hover{background:#5a6268;transform:translateY(-1px)}.actions button.primary{padding:8px;background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;font-size:12px;font-weight:600;font-family:inherit!important;transition:all .2s ease;box-shadow:0 2px 8px #28a74533;width:100%}.actions button.primary:hover:not(:disabled){background:linear-gradient(135deg,#218838 0%,#1ba085 100%);transform:translateY(-2px);box-shadow:0 4px 12px #28a7454d}.actions button.primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none}.printcard-page-wrapper .pages{flex:1;overflow:auto;padding:12px;background:#ececec;font-family:Times New Roman,Times,serif!important;min-height:0}.printcard-page-wrapper .preview-page{background:#fff;width:210mm;height:297mm;padding:10mm;box-shadow:0 4px 8px #0000001a;border-radius:15px;display:grid;grid-template-columns:repeat(2,1fr);grid-template-rows:repeat(4,1fr);gap:5mm;transform:scale(.67);transform-origin:top center;position:relative;margin-bottom:-360px}.printcard-page-wrapper .preview-card-container{display:flex;align-items:center;justify-content:center;position:relative}.printcard-page-wrapper .empty-state{text-align:center;padding:40px 20px;color:#6c757d;font-family:inherit!important}.printcard-page-wrapper .preview-cards{display:flex;flex-direction:column;gap:8px;align-items:center;width:100%}.printcard-page-wrapper .preview-navigation{display:flex;justify-content:center;align-items:center;gap:12px}.printcard-page-wrapper .preview-nav-btn{padding:8px 16px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:6px;font-size:12px;font-weight:500;transition:all .2s ease;pointer-events:auto;position:relative;z-index:10}.preview-nav-btn:hover:not(:disabled){background:linear-gradient(135deg,#5a6fd8 0%,#6a4190 100%);transform:translateY(-1px)}.preview-nav-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.printcard-page-wrapper .preview-page-info{color:#6c757d;font-size:14px;font-weight:500}.printcard-page-wrapper .preview-footer{padding:12px 16px;background:#f8f9fa;border-top:1px solid #e9ecef;color:#6c757d;font-size:14px;bottom:50px;font-family:Times New Roman,Times,serif!important;height:50px;flex-shrink:0;box-sizing:border-box;display:flex!important;align-items:center;justify-content:space-between;gap:16px;position:relative;z-index:10}.printcard-page-wrapper .footer-info{display:flex;align-items:center}.printcard-page-wrapper .loading-spinner{display:inline-block;width:20px;height:20px;border:2px solid #f3f3f3;border-top:2px solid #667eea;border-radius:50%;animation:spin 1s linear infinite}.empty-state svg{opacity:.3;margin-bottom:16px}.empty-state p{margin:0;font-size:16px;font-family:inherit!important}.printcard-page-wrapper .text-center{text-align:center}.printcard-page-wrapper .text-left{text-align:left}.printcard-page-wrapper .text-right{text-align:right}.printcard-page-wrapper .font-bold{font-weight:700}.printcard-page-wrapper .font-medium{font-weight:500}.printcard-page-wrapper .font-normal{font-weight:400}.printcard-page-wrapper .text-primary{color:#667eea}.printcard-page-wrapper .text-secondary{color:#6c757d}.printcard-page-wrapper .text-success{color:#28a745}.printcard-page-wrapper .text-danger{color:#dc3545}.printcard-page-wrapper .text-warning{color:#ffc107}.printcard-page-wrapper .text-info{color:#17a2b8}.printcard-page-wrapper .bg-primary{background-color:#667eea}.printcard-page-wrapper .bg-secondary{background-color:#6c757d}.printcard-page-wrapper .bg-success{background-color:#28a745}.printcard-page-wrapper .bg-danger{background-color:#dc3545}.printcard-page-wrapper .bg-warning{background-color:#ffc107}.printcard-page-wrapper .bg-info{background-color:#17a2b8}.printcard-page-wrapper .mb-0{margin-bottom:0}.printcard-page-wrapper .mb-1{margin-bottom:4px}.printcard-page-wrapper .mb-2{margin-bottom:8px}.printcard-page-wrapper .mb-3{margin-bottom:12px}.printcard-page-wrapper .mb-4{margin-bottom:16px}.printcard-page-wrapper .mb-5{margin-bottom:20px}.printcard-page-wrapper .mt-0{margin-top:0}.printcard-page-wrapper .mt-1{margin-top:4px}.printcard-page-wrapper .mt-2{margin-top:8px}.printcard-page-wrapper .mt-3{margin-top:12px}.printcard-page-wrapper .mt-4{margin-top:16px}.printcard-page-wrapper .mt-5{margin-top:20px}.printcard-page-wrapper .p-0{padding:0}.printcard-page-wrapper .p-1{padding:4px}.printcard-page-wrapper .p-2{padding:8px}.printcard-page-wrapper .p-3{padding:12px}.printcard-page-wrapper .p-4{padding:16px}.printcard-page-wrapper .p-5{padding:20px}@media (max-width: 1400px){.printcard-page-wrapper .preview-page{transform:scale(.5);margin-bottom:-70px}.printcard-page-wrapper .preview-wrap{width:500px!important}.printcard-page-wrapper .left{width:calc(100% - 500px)!important}}@media (max-width: 1200px){.printcard-page-wrapper .preview-page{transform:scale(.45);margin-bottom:-80px}.printcard-page-wrapper .preview-wrap{width:450px!important}.printcard-page-wrapper .left{width:calc(100% - 450px)!important}}@media (max-width: 1024px){.printcard-page-wrapper .shell{flex-direction:column!important;height:auto!important}.printcard-page-wrapper .left{width:100%!important;height:60vh!important}.printcard-page-wrapper .preview-wrap{width:100%!important;height:40vh!important}.printcard-page-wrapper .preview-page{transform:scale(.3);margin-bottom:-120px}.printcard-page-wrapper .pages{height:calc(40vh - 100px)!important}}@media (max-width: 768px){.printcard-page-wrapper .font-control-btn{width:20px!important;height:20px!important;font-size:12px!important}.printcard-page-wrapper .card-remove-btn{width:18px!important;height:18px!important;font-size:10px!important}.printcard-page-wrapper .preview-navigation{flex-wrap:wrap;gap:8px}.printcard-page-wrapper .preview-nav-btn{padding:6px 12px;font-size:11px}}.printcard-page-wrapper .print-preview-modal{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:9999;display:flex;align-items:center;justify-content:center;font-family:Times New Roman,Times,serif!important}.printcard-page-wrapper .print-preview-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,.5);-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.printcard-page-wrapper .print-preview-container{position:relative;width:90vw;height:90vh;max-width:1200px;background:white;border-radius:12px;box-shadow:0 20px 40px #0000004d;display:flex;flex-direction:column;overflow:hidden}.printcard-page-wrapper .print-preview-header{padding:16px 24px;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.print-preview-header h3{margin:0;font-size:18px;font-weight:600}.printcard-page-wrapper .close-btn{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:4px 8px;border-radius:4px;transition:background .2s ease}.close-btn:hover{background:rgba(255,255,255,.2)}.printcard-page-wrapper .print-preview-content{flex:1;overflow:auto;background:#ececec;padding:20px}.printcard-page-wrapper .print-preview-pages{display:flex;flex-direction:column;gap:20px;align-items:center}.print-preview-modal .preview-page{transform:scale(.8);margin-bottom:-200px}.printcard-page-wrapper .print-preview-footer{padding:16px 24px;background:#f8f9fa;border-top:1px solid #e9ecef;display:flex;align-items:center;justify-content:space-between;flex-shrink:0}.printcard-page-wrapper .print-info{color:#6c757d;font-size:14px}.printcard-page-wrapper .print-actions{display:flex;gap:12px}.printcard-page-wrapper .cancel-btn{padding:10px 20px;background:#6c757d;color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease}.cancel-btn:hover{background:#5a6268}.printcard-page-wrapper .print-btn{padding:10px 20px;background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff;border:none;border-radius:6px;cursor:pointer;display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;transition:all .2s ease;box-shadow:0 2px 8px #28a74533}.print-btn:hover{background:linear-gradient(135deg,#218838 0%,#1ba085 100%);transform:translateY(-1px);box-shadow:0 4px 12px #28a7454d}.printcard-page-wrapper .print-preview-modal{animation:modalFadeIn .3s ease-out}.printcard-page-wrapper .print-preview-container{animation:modalSlideIn .3s ease-out}@keyframes modalFadeIn{0%{opacity:0}to{opacity:1}}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}@media (max-width: 768px){.printcard-page-wrapper .print-preview-container{width:95vw;height:95vh}.print-preview-modal .preview-page{transform:scale(.4);margin-bottom:-300px}.printcard-page-wrapper .print-actions{flex-direction:column;gap:8px}.printcard-page-wrapper .cancel-btn,.printcard-page-wrapper .print-btn{width:100%;justify-content:center}.printcard-page-wrapper .pane-footer{flex-direction:column;height:auto;gap:8px;padding:8px}.printcard-page-wrapper .footer-left,.printcard-page-wrapper .footer-right,.printcard-page-wrapper .footer-center{flex:none;width:100%;justify-content:center;text-align:center}.printcard-page-wrapper .pagination{gap:8px}.printcard-page-wrapper .pagination button{padding:6px 12px;font-size:12px;min-width:60px}.printcard-page-wrapper #pageInfo{font-size:12px;padding:6px 12px}}.printcard-page-wrapper .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);display:flex;align-items:center;justify-content:center;z-index:10000;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif}.printcard-page-wrapper .modal-content{background:white;border-radius:8px;box-shadow:0 10px 30px #0000004d;max-width:500px;width:90%;max-height:90vh;overflow:hidden;animation:modalAppear .2s ease-out}@keyframes modalAppear{0%{opacity:0;transform:scale(.9) translateY(-10px)}to{opacity:1;transform:scale(1) translateY(0)}}.printcard-page-wrapper .modal-header{padding:20px 24px 16px;border-bottom:1px solid #e5e7eb;background:#f9fafb}.modal-header h3{margin:0;font-size:18px;font-weight:600;color:#111827}.printcard-page-wrapper .modal-body{padding:24px;color:#374151;line-height:1.5}.modal-body p{margin:0 0 16px}.modal-body p:last-child{margin-bottom:0}.modal-body .text-secondary{font-size:14px;color:#6b7280}.printcard-page-wrapper .modal-footer{padding:16px 24px 24px;display:flex;gap:12px;justify-content:flex-end;background:#f9fafb;border-top:1px solid #e5e7eb}.printcard-page-wrapper .btn-secondary{padding:8px 16px;border:1px solid #d1d5db;background:white;color:#374151;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-secondary:hover{background:#f3f4f6;border-color:#9ca3af}.printcard-page-wrapper .btn-primary{padding:8px 16px;border:1px solid #3b82f6;background:#3b82f6;color:#fff;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.btn-primary:hover{background:#2563eb;border-color:#2563eb}.printcard-page .preview-footer .footer-info{text-align:center!important;display:flex!important;justify-content:center!important;align-items:center!important;width:100%!important}.printcard-page .preview-footer .footer-info span{text-align:center!important;display:block!important;width:100%!important}.background-blur{position:absolute;left:50%;top:52%;width:8cm;height:auto;transform:translate(-50%,-50%);-o-object-fit:contain;object-fit:contain;opacity:.2;z-index:0;pointer-events:none;max-width:135%;max-height:135%}.card-slot{width:8.5cm;height:5.4cm;box-sizing:border-box;display:flex;align-items:center;justify-content:center;margin:.5cm .3cm;float:left;border:none;border-radius:2mm;background:transparent}.card-slot.has-card{border:1.5px dashed #333;position:relative}.card-font-controls{position:absolute;top:100px;left:5px;right:5px;display:flex!important;justify-content:space-between;align-items:center;z-index:999;width:calc(100% - 117px);pointer-events:auto!important;height:25px;background:rgba(255,255,255,.1);border-radius:4px}.card-font-controls button{pointer-events:auto!important;cursor:pointer!important}.card-remove-btn{position:absolute;top:0;right:0;width:30px;height:30px;border:2px solid #dc3545;background:rgba(220,53,69,.9);border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff;line-height:1;box-shadow:0 2px 6px #0000004d;transition:all .2s ease;z-index:1001;pointer-events:auto}.card-remove-btn:hover{background:rgba(185,28,28,.95);transform:scale(1.1);border-color:#b91c1c}.card-remove-btn:active{transform:scale(.95)}.card-font-controls .font-control-btn{pointer-events:auto}@media print{.card-font-controls,.card-remove-btn{display:none!important}}.font-control-btn{width:24px!important;height:24px!important;border:2px solid #333!important;background:rgba(255,255,255,.95)!important;border-radius:50%!important;cursor:pointer!important;display:flex!important;align-items:center!important;justify-content:center!important;font-size:14px!important;font-weight:700!important;color:#333!important;line-height:1!important;box-shadow:0 2px 6px #0000004d!important;transition:all .2s ease!important;z-index:1000!important;pointer-events:auto!important;position:relative!important}.font-control-btn:hover{background:rgba(240,240,240,.95);transform:scale(1.1);border-color:#000}.font-control-btn:active{transform:scale(.95);background:rgba(220,220,220,.95)}.id-card-container{width:8.3cm;height:5.2cm;box-sizing:border-box;padding:2mm;border:1.2px solid #333;border-radius:2mm;background:#fff;position:relative;overflow:hidden;display:flex;flex-direction:row;align-items:stretch;justify-content:space-between;margin:0 auto;font-family:Times New Roman,Times,serif!important}.id-left,.id-center,.id-right{position:absolute;top:0;bottom:0}.id-left{left:0;width:16%;height:100%}.id-right{right:0;width:35%;height:100%;align-items:center}.qr-cccd{position:static;width:50px;height:50px;margin:0 auto 2px;display:block}.label-cccd{position:static;font-size:1em;color:#b71c1c;font-weight:500;text-align:center;margin-top:2px}.qr-msnv{position:static;width:50px;height:50px;margin:0 auto 2px;display:block}.msnv-label{position:static;font-size:1em;color:#b71c1c;font-weight:500;text-align:center;margin-top:2px}.field-name{position:absolute;top:45%;left:0;width:calc(72% - 20px);padding:0 10px;transform:translateY(-50%);text-align:center;font-size:1em;font-weight:700;letter-spacing:.1px;color:#181818;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.field-name span.name-fit{display:inline-block;width:100%;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:inherit;text-align:center}.field-id{position:absolute;top:62%;left:0;width:calc(72% - 20px);padding:0 10px;transform:translateY(-50%);text-align:center;font-size:1.5em;font-weight:400;letter-spacing:.5px;color:#555;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;display:block}.field-id span{display:inline-block;width:100%;max-width:100%;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:inherit;text-align:center}.dept{position:absolute;bottom:18px;left:11%;width:calc(65% - 20px);padding:0 10px;text-align:center;font-size:1.2em;color:#222;font-weight:500;line-height:1.2}.company-logo{position:absolute;top:-5px;right:25px;width:60px;height:auto;-webkit-text-emphasis:center;text-emphasis:center;-o-object-fit:contain;object-fit:contain}.company-name{position:absolute;top:45px;right:0;width:108px;height:18px;background:#1565c0;color:#fff;font-size:.5em;font-weight:700;letter-spacing:.1px;text-align:center;border-radius:6px;line-height:18px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;box-shadow:0 2px 8px #e3eaf7}.avatar{position:absolute;bottom:2px;right:2px;width:2.76cm;height:3.37cm;-o-object-fit:cover;object-fit:cover;border-radius:2mm;border:1px solid #aaa;background:#eee}.qr-cccd-wrap{padding:2px;margin:3px;display:flex;flex-direction:column;align-items:center;width:-moz-fit-content;width:fit-content}.qr-msnv-wrap{padding:2px;margin:3px;display:flex;flex-direction:column;align-items:center;width:-moz-fit-content;width:fit-content;position:absolute;left:0;bottom:-4px}.qr-cccd-wrap img,.qr-msnv-wrap img{border:1px solid #888;border-radius:6px;display:block;margin:0;padding:2px;width:1cm;height:1cm}.label-cccd,.msnv-label{text-align:center;margin-top:2px;font-size:.8em}.filter-menu{position:absolute;top:100%;left:0;right:0;background:white;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:1000;max-height:400px;display:flex;flex-direction:column;font-size:14px}.filter-values{flex:1;overflow-y:auto;max-height:250px;padding:4px 0}.filter-value-text{flex:1;line-height:1.4;word-break:break-word;cursor:pointer;margin-right:8px}.filter-value-count{font-size:11px;color:#666;background-color:#e9ecef;padding:2px 6px;border-radius:10px;font-weight:500;flex-shrink:0;min-width:-moz-fit-content;min-width:fit-content}.menu-actions{padding:8px;border-top:1px solid #eee;display:flex;gap:8px;background:#f9f9f9}.menu-actions button{flex:1;padding:6px 12px;border:1px solid #ddd;border-radius:3px;background:white;cursor:pointer;font-size:12px}.menu-actions button:hover{background:#f5f5f5}.menu-actions button:first-child{background:#007bff;color:#fff;border-color:#007bff;font-weight:500}.menu-actions button:first-child:hover{background:#0056b3;border-color:#0056b3}.menu-actions button:last-child{background:#6c757d;color:#fff;border-color:#6c757d}.menu-actions button:last-child:hover{background:#545b62;border-color:#545b62}.filter-values::-webkit-scrollbar{width:6px}.filter-values::-webkit-scrollbar-track{background:#f1f1f1}.filter-values::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.ac-wrapper,.ac-header,.ac-stats-bar{position:relative;z-index:1!important}.ac-filter-panel{position:relative;z-index:10!important}.ac-data-table-container,.ac-attendance-table,.ac-attendance-table thead,.ac-attendance-table tbody,.ac-loading-overlay{position:relative;z-index:1!important}body{overflow:visible!important;position:relative!important;z-index:auto!important}.ac-wrapper{min-height:100vh;background:linear-gradient(135deg,#f5f7fa 0%,#c3cfe2 100%);padding:10px;font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;overflow:visible}.ac-header{display:flex;justify-content:space-between;align-items:center;background:white;padding:20px 30px;border-radius:15px;box-shadow:0 4px 20px #0000001a;margin-bottom:10px;border:1px solid #e1e5e9}.ac-header-left{display:flex;flex-direction:column;gap:10px}.ac-page-title{display:flex;align-items:center;gap:12px}.ac-title-icon{color:#2563eb;width:28px;height:28px;flex-shrink:0}.ac-page-title h1{font-size:28px;font-weight:700;color:#1f2937;margin:0;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ac-update-info{display:flex;align-items:center;gap:15px}.ac-last-update{font-size:14px;color:#6b7280;font-weight:500}.ac-auto-refresh-indicator{display:flex;align-items:center;gap:6px;font-size:13px;color:#059669;font-weight:500}.ac-refresh-dot{width:8px;height:8px;background:#10b981;border-radius:50%;animation:ac-pulse 2s infinite}@keyframes ac-pulse{0%,to{opacity:1}50%{opacity:.5}}.ac-header-controls{display:flex;align-items:center;gap:15px}.ac-date-picker,.ac-date-range-picker{display:flex;align-items:center;gap:8px;background:#f8fafc;padding:10px 15px;border-radius:10px;border:2px solid #e2e8f0;transition:all .3s ease;box-sizing:border-box}.ac-date-picker:focus-within,.ac-date-range-picker:focus-within{border-color:#2563eb;background:white;box-shadow:0 0 0 3px #2563eb1a}.ac-date-inputs{display:flex;gap:15px;align-items:center;flex:1;min-width:0;box-sizing:border-box}.ac-date-input-group{display:flex;flex-direction:column;gap:4px}.ac-date-input-group label{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.5px}.ac-calendar-icon{color:#64748b;width:18px;height:18px}.ac-date-input{border:none;background:transparent;font-size:14px;font-weight:500;outline:none;box-sizing:border-box;flex-shrink:1}.ac-filter-toggle-btn,.ac-auto-refresh-btn,.ac-manual-refresh-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;border:2px solid;border-radius:10px;font-weight:600;font-size:14px;cursor:pointer;transition:all .3s ease;background:white}.ac-mobile-filter-btn{display:none}.ac-filter-toggle-btn{border-color:#7c3aed;color:#7c3aed}.ac-filter-toggle-btn:hover{background:#7c3aed;color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #7c3aed4d}.ac-auto-refresh-btn{border-color:#059669;color:#059669}.ac-auto-refresh-btn.active{background:#059669;color:#fff;box-shadow:0 4px 15px #0596694d}.ac-auto-refresh-btn:hover:not(.active){background:#059669;color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #0596694d}.ac-manual-refresh-btn{border-color:#2563eb;color:#2563eb}.ac-manual-refresh-btn:hover:not(:disabled){background:#2563eb;color:#fff;transform:translateY(-2px);box-shadow:0 4px 15px #2563eb4d}.ac-manual-refresh-btn:disabled{opacity:.6;cursor:not-allowed}.ac-spinning{animation:ac-spin 1s linear infinite}@keyframes ac-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.ac-filter-panel{background:white;padding:20px 30px;border-radius:15px;box-shadow:0 4px 20px #0000001a;margin-bottom:10px;border:1px solid #e1e5e9;position:relative;z-index:10!important;overflow:visible!important;width:100%;box-sizing:border-box}.ac-filter-grid{display:flex;align-items:end;gap:20px;flex-wrap:wrap;width:100%;max-width:100%;overflow:hidden;box-sizing:border-box}.ac-filter-row{display:contents}.ac-filter-item{display:flex;flex-direction:column;gap:1px;flex:1;min-width:200px;max-width:100%;box-sizing:border-box}.ac-filter-item label{font-weight:600;font-size:14px}.ac-filter-item input{padding:10px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;background:#f9fafb;transition:all .3s ease}.ac-filter-item input:focus{outline:none;border-color:#2563eb;background:white;box-shadow:0 0 0 3px #2563eb1a}.ac-filter-select{padding:10px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;background:#f9fafb;transition:all .3s ease;cursor:pointer}.ac-filter-select:focus{outline:none;border-color:#2563eb;background:white;box-shadow:0 0 0 3px #2563eb1a}.ac-multi-select-container{position:relative;width:100%;z-index:1000!important;isolation:isolate}.ac-multi-select-container.dropdown-open{z-index:999999999!important}.ac-multi-select-display{min-height:42px;padding:8px 12px;border:2px solid #e5e7eb;border-radius:8px;background:#f9fafb;cursor:pointer;transition:all .3s ease;position:relative;z-index:1}.ac-multi-select-container.dropdown-active .ac-multi-select-display{z-index:-1}.ac-multi-select-container.dropdown-active .ac-multi-select-dropdown{z-index:999999999!important}.ac-multi-select-display:hover{border-color:#d1d5db;background:white}.ac-multi-select-display:focus-within{border-color:#2563eb;background:white;box-shadow:0 0 0 3px #2563eb1a}.ac-placeholder{color:#9ca3af;font-style:italic;display:flex;align-items:center;min-height:24px;font-size:14px}.ac-selected-items{display:flex;flex-wrap:wrap;gap:6px;min-height:24px;align-items:center}.ac-selected-item{display:inline-flex;align-items:center;gap:6px;background:#dbeafe;border:1px solid #2563eb;color:#1e40af;padding:4px 8px;border-radius:6px;font-size:12px;font-weight:500;max-width:150px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.ac-remove-item{background:none;border:none;color:#ef4444;font-size:16px;font-weight:700;cursor:pointer;padding:0;width:16px;height:16px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background-color .2s ease}.ac-remove-item:hover{background-color:#fee2e2}.ac-multi-select-wrapper{position:relative;z-index:999999!important;isolation:isolate}.ac-multi-select-container .ac-multi-select-dropdown,.ac-multi-select-wrapper .ac-multi-select-dropdown{z-index:999999!important}.ac-multi-select-dropdown{position:absolute!important;top:calc(100% + 2px)!important;left:0!important;right:0!important;background:white!important;border:2px solid #e5e7eb!important;border-radius:8px!important;max-height:300px!important;overflow-y:auto!important;z-index:999999999!important;opacity:0!important;visibility:hidden!important;transform:translateY(-10px) translateZ(0)!important;transition:all .3s ease!important;min-width:180px!important;pointer-events:auto!important;box-shadow:0 8px 25px #00000026!important;will-change:transform,opacity!important}.ac-multi-select-wrapper,.ac-filter-row-1,.ac-filter-row-2,.ac-filter-row-3,.ac-filter-grid{overflow:visible!important}.ac-multi-select-dropdown:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.1);z-index:-1;pointer-events:none}.ac-multi-select-dropdown.ac-show{opacity:1!important;visibility:visible!important;transform:translateY(0) translateZ(0)!important;z-index:999999999!important}@media (max-width: 768px){.ac-multi-select-container,.ac-multi-select-wrapper{position:relative!important;z-index:999999!important}.ac-multi-select-dropdown{position:absolute!important;top:100%!important;left:0!important;right:0!important;max-height:40vh!important;border-radius:12px!important;margin-top:4px!important;box-shadow:0 10px 40px #00000040!important;z-index:999999999!important}.ac-multi-select-dropdown.ac-show{transform:translateY(0)!important}.ac-multi-select-dropdown.ac-position-below{top:var(--dropdown-top, 50%)!important}.ac-multi-select-dropdown.ac-position-above{bottom:var(--dropdown-bottom, 50%)!important;top:auto!important}.ac-multi-select-dropdown.ac-position-center{top:50%!important;transform:translateY(-50%)!important}.ac-multi-select-dropdown:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3);z-index:-1;pointer-events:none}.ac-filter-panel,.ac-filter-grid,.ac-filter-row-1,.ac-filter-row-2,.ac-filter-row-3{overflow:visible!important;position:relative!important}}.ac-checkbox-item{display:flex;align-items:center;gap:8px;padding:10px 12px;cursor:pointer;transition:background-color .2s ease;border-bottom:1px solid #f3f4f6;background-color:transparent!important;background:none!important}.ac-checkbox-item,.ac-checkbox-item:link,.ac-checkbox-item:visited,.ac-checkbox-item:focus,.ac-checkbox-item:active,.ac-checkbox-item:target,.ac-checkbox-item[style]{background:transparent!important;background-color:transparent!important;background-image:none!important}.ac-checkbox-item:last-child{border-bottom:none}.ac-checkbox-item:hover{background-color:#f9fafb!important;background:#f9fafb!important}.ac-checkbox-item input[type=checkbox]{margin:0;cursor:pointer;accent-color:#2563eb}.ac-checkbox-item span{flex:1;font-size:14px}.ac-select-all{background-color:transparent!important;background:none!important;border-bottom:2px solid #e5e7eb;font-weight:600}.ac-select-all,.ac-select-all:link,.ac-select-all:visited,.ac-select-all:focus,.ac-select-all:active,.ac-select-all:target,.ac-select-all[style]{background:transparent!important;background-color:transparent!important;background-image:none!important}.ac-select-all:hover{background-color:#f1f5f9!important;background:#f1f5f9!important}.ac-select-all span{color:#1f2937}.ac-dropdown-divider{height:1px;background-color:#e5e7eb;margin:4px 0}.ac-empty-option{background-color:transparent!important;background:none!important;border-top:1px solid #f59e0b;border-bottom:1px solid #f59e0b}.ac-empty-option,.ac-empty-option:link,.ac-empty-option:visited,.ac-empty-option:focus,.ac-empty-option:active,.ac-empty-option:target,.ac-empty-option[style]{background:transparent!important;background-color:transparent!important;background-image:none!important}.ac-empty-option:hover{background-color:#fef3c7!important;background:#fef3c7!important}.ac-empty-option span{color:#92400e;font-style:italic}.ac-multi-select-dropdown .ac-checkbox-item,.ac-multi-select-dropdown .ac-select-all,.ac-multi-select-dropdown .ac-empty-option,.ac-multi-select-dropdown label,.ac-multi-select-dropdown .ac-checkbox-item *,.ac-multi-select-dropdown .ac-select-all *,.ac-multi-select-dropdown .ac-empty-option *{background-color:transparent!important;background:none!important;background-image:none!important}.ac-multi-select-dropdown label{background-color:transparent!important;background:transparent!important;background-image:none!important;color:inherit!important}.ac-multi-select-dropdown *[class]{background-color:transparent!important;background:none!important}.ac-multi-select-dropdown .ac-checkbox-item:before,.ac-multi-select-dropdown .ac-checkbox-item:after,.ac-multi-select-dropdown .ac-select-all:before,.ac-multi-select-dropdown .ac-select-all:after,.ac-multi-select-dropdown .ac-empty-option:before,.ac-multi-select-dropdown .ac-empty-option:after,.ac-multi-select-dropdown label:before,.ac-multi-select-dropdown label:after{background-color:transparent!important;background:none!important;content:none!important;display:none!important}.ac-multi-select-dropdown .ac-checkbox-item:active,.ac-multi-select-dropdown .ac-checkbox-item:focus,.ac-multi-select-dropdown .ac-checkbox-item:visited,.ac-multi-select-dropdown .ac-select-all:active,.ac-multi-select-dropdown .ac-select-all:focus,.ac-multi-select-dropdown .ac-select-all:visited,.ac-multi-select-dropdown .ac-empty-option:active,.ac-multi-select-dropdown .ac-empty-option:focus,.ac-multi-select-dropdown .ac-empty-option:visited,.ac-multi-select-dropdown label:active,.ac-multi-select-dropdown label:focus,.ac-multi-select-dropdown label:visited{background-color:transparent!important;background:none!important}.ac-multi-select-dropdown .ac-checkbox-item:hover,.ac-multi-select-dropdown .ac-select-all:hover{background-color:#f9fafb!important;background:#f9fafb!important}.ac-loading-option{padding:10px 12px;text-align:center;color:#9ca3af;font-style:italic;font-size:14px}.ac-multi-select-dropdown *,.ac-multi-select-dropdown *:before,.ac-multi-select-dropdown *:after{background-color:transparent!important;background:transparent!important;background-image:none!important}.ac-multi-select-dropdown{background-color:#fff!important;background:white!important}.ac-multi-select-dropdown>*,.ac-multi-select-dropdown label,.ac-multi-select-dropdown .ac-checkbox-item,.ac-multi-select-dropdown .ac-select-all,.ac-multi-select-dropdown .ac-empty-option{background-color:transparent!important;background:none!important;background-image:none!important}.ac-multi-select-dropdown *:not(:hover),.ac-multi-select-dropdown *:not(.ac-checkbox-item:hover),.ac-multi-select-dropdown *:not(.ac-select-all:hover),.ac-multi-select-dropdown *:not(.ac-empty-option:hover){background:none!important;background-color:transparent!important}.ac-multi-select-dropdown [style*=background]{background:transparent!important;background-color:transparent!important}.ac-multi-select-dropdown *:nth-child(odd),.ac-multi-select-dropdown *:nth-child(2n),.ac-multi-select-dropdown *:nth-of-type(odd),.ac-multi-select-dropdown *:nth-of-type(2n){background-color:transparent!important;background:none!important}.ac-multi-select-dropdown .ac-checkbox-item:hover{background-color:#f9fafb!important;background:#f9fafb!important}.ac-multi-select-dropdown .ac-select-all:hover{background-color:#f1f5f9!important;background:#f1f5f9!important}.ac-multi-select-dropdown .ac-empty-option:hover{background-color:#fef3c7!important;background:#fef3c7!important}.ac-pagination-container{display:flex;justify-content:space-between;align-items:center;padding:20px;background:white;border-top:1px solid #e5e7eb;flex-wrap:wrap;gap:15px}.ac-pagination-footer{display:flex;justify-content:space-between;align-items:center;padding:10px 20px;background:white;border:1px solid #e1e5e9;border-top:none;border-radius:0 0 15px 15px;box-shadow:0 4px 20px #0000001a;flex-wrap:wrap;gap:15px;max-width:100%;box-sizing:border-box}.ac-pagination-info{display:flex;align-items:center;gap:15px;font-size:14px;color:#6b7280}.ac-items-per-page{display:flex;align-items:center;gap:8px}.ac-page-size-select{padding:8px 12px;border:2px solid #e5e7eb;border-radius:8px;font-size:14px;background:white;cursor:pointer;min-width:120px;transition:all .2s ease}.ac-page-size-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.ac-page-size-select:hover{border-color:#9ca3af}.ac-pagination-controls{display:flex;align-items:center;gap:8px;max-width:100%;box-sizing:border-box}.ac-pagination-btn{padding:8px 12px;border:1px solid #d1d5db;background:white;font-size:14px;border-radius:6px;cursor:pointer;transition:all .2s ease;min-width:40px;display:flex;align-items:center;justify-content:center}.ac-pagination-btn:hover:not(:disabled){background:#f9fafb;border-color:#9ca3af}.ac-pagination-btn:disabled{opacity:.5;cursor:not-allowed;background:#f9fafb;color:#9ca3af}.ac-pagination-active{background:#2563eb!important;color:#fff!important;border-color:#2563eb!important}.ac-pagination-active:hover{background:#1d4ed8!important}.ac-pagination-pages{display:flex;align-items:center;gap:4px;max-width:100%;flex-wrap:wrap;justify-content:center}.ac-pagination-ellipsis{padding:8px 4px;color:#9ca3af;font-size:14px}.ac-pagination-jump{display:flex;align-items:center;gap:8px;font-size:14px;color:#6b7280}.ac-page-jump-input{width:60px;padding:6px 8px;border:1px solid #d1d5db;border-radius:6px;text-align:center;font-size:14px}.ac-page-jump-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.ac-pagination-footer.ac-single-page{justify-content:space-between}.ac-single-page-info{display:flex;align-items:center;font-size:14px;color:#6b7280;font-weight:500}.ac-unknown-machine{color:#f59e0b!important;font-style:italic}.ac-machine-status{font-size:11px;color:#ef4444;font-weight:500;margin-left:4px}.ac-employee-avatar{width:28px;height:28px;border-radius:50%;-o-object-fit:cover;object-fit:cover;margin-right:8px;border:2px solid #e5e7eb;box-shadow:0 1px 3px #0000001a;transition:all .2s ease}.ac-employee-avatar:hover{border-color:#2563eb;transform:scale(1.1);box-shadow:0 2px 8px #2563eb33}@media (max-width: 768px){.ac-pagination-container,.ac-pagination-footer{flex-direction:column;gap:15px;padding:15px 20px;max-width:100%;box-sizing:border-box}.ac-pagination-controls{flex-wrap:wrap;justify-content:center;max-width:100%}.ac-pagination-pages{order:3;flex-wrap:wrap;justify-content:center;max-width:100%}.ac-pagination-info{flex-direction:column;text-align:center;gap:10px;width:100%}.ac-items-per-page{justify-content:center;flex-wrap:wrap}}.ac-filter-actions{display:flex;align-items:end;justify-content:flex-end;margin-left:auto;flex-shrink:0;gap:10px}.ac-clear-filters-btn{padding:10px 16px;background:#ef4444;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease}.ac-clear-filters-btn:hover{background:#dc2626;transform:translateY(-2px);box-shadow:0 4px 15px #ef44444d}.ac-export-excel-btn{padding:10px 16px;background:#059669;color:#fff;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;gap:6px}.ac-export-excel-btn:hover{background:#047857;transform:translateY(-2px);box-shadow:0 4px 15px #0596694d}.ac-export-excel-btn:active{transform:translateY(0)}.ac-stats-bar{display:flex;gap:20px;background:white;padding:20px 30px;border-radius:15px;box-shadow:0 4px 20px #0000001a;margin-bottom:10px;border:1px solid #e1e5e9;align-items:center;width:100%;box-sizing:border-box;overflow:hidden}.ac-stats-desktop{display:flex;flex-wrap:nowrap;justify-content:space-between}.ac-stats-desktop .ac-stat-item{flex:1;min-width:0;max-width:none}.ac-stats-desktop .ac-stat-date-picker{flex:1.5;min-width:300px}.ac-stats-desktop .ac-stat-filter{flex:0 0 auto;margin-left:20px}.ac-stats-mobile{display:none}@media (max-width: 768px){.ac-stats-desktop{display:none}.ac-stats-mobile{display:flex;flex-direction:column;gap:15px}}.ac-stats-mobile-row{display:contents}.ac-stat-item{display:flex;flex-direction:column;gap:5px;text-align:center;flex:1;min-width:0;max-width:100%;box-sizing:border-box}.ac-stat-label{font-size:14px;color:#6b7280;font-weight:500}.ac-stat-value{font-size:24px;font-weight:700;color:#1f2937;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.ac-stat-filter{flex:none!important;margin-left:auto;text-align:right}.ac-stat-filter .ac-filter-toggle-btn{padding:12px;min-width:48px;min-height:48px;display:flex;align-items:center;justify-content:center;font-size:0}.ac-stat-filter .ac-filter-toggle-btn:hover{transform:translateY(-2px) scale(1.05)}.ac-stat-date-picker{flex:1.5!important;display:flex;flex-direction:column;align-items:center;text-align:center;min-width:0;max-width:100%;box-sizing:border-box;justify-content:center}.ac-stat-date-picker .ac-stat-label{margin-bottom:8px}.ac-stat-date-picker .ac-date-range-picker{padding:8px 12px;border-radius:10px;transition:all .3s ease;display:flex;align-items:center;gap:8px;justify-content:center;width:auto;max-width:400px;min-width:280px;box-sizing:border-box}.ac-stat-date-picker .ac-calendar-icon{color:#6b7280;width:16px;height:16px;flex-shrink:0}.ac-stat-date-picker .ac-date-inputs{display:flex;gap:8px;align-items:center;flex:1;min-width:0}.ac-stat-date-picker .ac-date-separator{font-size:16px;font-weight:700;color:#1f2937;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;margin:0 4px;flex-shrink:0}.ac-stat-date-picker .ac-date-input{padding:4px 6px;border:none;border-radius:6px;font-size:14px;font-weight:700;color:#1f2937;background:linear-gradient(135deg,#2563eb,#7c3aed);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;background-color:transparent;transition:all .2s ease;flex:1;min-width:90px;max-width:120px;text-align:center;box-sizing:border-box}.ac-stat-date-picker .ac-date-input::-moz-selection{background:rgba(37,99,235,.3);color:#1f2937;-webkit-text-fill-color:#1f2937}.ac-stat-date-picker .ac-date-input::selection{background:rgba(37,99,235,.3);color:#1f2937;-webkit-text-fill-color:#1f2937}.ac-stat-date-picker .ac-date-input::-moz-selection{background:rgba(37,99,235,.3);color:#1f2937}.ac-stat-date-picker .ac-date-input:focus{outline:none}.ac-data-table-container{background:white;border-radius:15px 15px 0 0;box-shadow:0 4px 20px #0000001a;overflow:hidden;border:1px solid #e1e5e9;position:relative;display:flex;flex-direction:column;max-height:74vh;z-index:1!important}.ac-loading-overlay{position:absolute;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.9);display:flex;flex-direction:column;justify-content:center;align-items:center;gap:15px;z-index:1}.ac-loading-spinner{width:40px;height:40px;color:#2563eb;animation:ac-spin 1s linear infinite}.ac-attendance-table{width:100%;border-collapse:separate;border-spacing:0;font-size:14px;position:relative;display:flex;flex-direction:column;height:100%}.ac-attendance-table thead{background:linear-gradient(135deg,#2563eb,#7c3aed);color:#fff;display:block;width:100%;padding-right:8px;box-sizing:border-box;z-index:1;position:relative}.ac-attendance-table thead tr{display:table;width:100%;table-layout:fixed}.ac-attendance-table th{padding:12px 8px;text-align:center;font-weight:600;font-size:13px;white-space:nowrap;border-right:1px solid rgba(255,255,255,.2);background:linear-gradient(135deg,#2563eb,#7c3aed);position:relative;box-sizing:border-box}.ac-attendance-table th:last-child{border-right:none}.ac-th-stt{min-width:60px;width:4%;text-align:center}.ac-th-employee-code{min-width:120px;width:8%;text-align:center}.ac-th-name{min-width:250px;width:20%;text-align:center}.ac-th-department{min-width:120px;width:10%;text-align:center}.ac-th-workshop{min-width:100px;width:8%;text-align:center}.ac-th-machine{min-width:130px;width:12%;text-align:center}.ac-th-date{min-width:100px;width:8%;text-align:center}.ac-th-count{min-width:80px;width:6%;text-align:center}.ac-th-time-1,.ac-th-time-2,.ac-th-time-3,.ac-th-time-4,.ac-th-time-5,.ac-th-time-6,.ac-th-time-7,.ac-th-time-8,.ac-th-time-9{min-width:90px;width:4.4%;text-align:center}.ac-th-time-10{min-width:82px;width:4.4%;text-align:center}.ac-attendance-table tbody{display:block;overflow-y:auto;flex:1;max-height:calc(74vh - 60px);width:100%}.ac-attendance-table tbody::-webkit-scrollbar{width:8px}.ac-attendance-table tbody::-webkit-scrollbar-track{background:#f1f5f9;border-radius:4px}.ac-attendance-table tbody::-webkit-scrollbar-thumb{background:#cbd5e1;border-radius:4px}.ac-attendance-table tbody::-webkit-scrollbar-thumb:hover{background:#94a3b8}.ac-attendance-table tbody tr{display:table;width:100%;table-layout:fixed;border-bottom:1px solid #f1f5f9;transition:all .3s ease}.ac-attendance-table tbody tr:hover{background:#f8fafc}.ac-attendance-table tbody tr:nth-child(2n){background:rgba(248,250,252,.5)}.ac-attendance-table tbody tr:nth-child(2n):hover{background:#f1f5f9}.ac-attendance-table td{padding:10px 6px;vertical-align:middle;border-right:1px solid #f1f5f9;box-sizing:border-box}.ac-attendance-table td:last-child{border-right:none}.ac-td-stt{min-width:60px;width:4%;text-align:center;font-weight:600;color:#6b7280}.ac-fingerprint-code{display:inline-block;background:#ddd6fe;color:#7c3aed;padding:4px 8px;border-radius:6px;font-weight:600;font-size:12px}.td-name{min-width:250px;width:20%;text-align:left;padding-left:10px!important;padding-right:6px!important}.ac-employee-info{display:flex;align-items:center;gap:8px}.ac-employee-info svg{color:#64748b}.ac-employee-name{font-weight:600;color:#1f2937}.td-employee-code{min-width:120px;width:8%;text-align:center}.ac-employee-code{display:inline-block;background:#bfdbfe;color:#2563eb;padding:4px 8px;border-radius:6px;font-weight:600;font-size:12px}.td-department{min-width:120px;width:10%;text-align:center}.td-workshop{min-width:100px;width:8%;text-align:center}.td-machine{min-width:130px;width:12%;text-align:center}.td-count{min-width:80px;width:6%;text-align:center}.ac-latest-time{font-weight:600;color:#059669;background:#d1fae5;padding:4px 8px;border-radius:6px;font-size:12px}.ac-check-count{display:inline-block;padding:4px 8px;border-radius:6px;font-weight:600;font-size:12px;min-width:30px;text-align:center}.ac-check-count.low{background:#fecaca;color:#dc2626}.ac-check-count.medium{background:#fed7aa;color:#ea580c}.ac-check-count.high{background:#bbf7d0;color:#059669}.ac-td-time{min-width:90px;width:4.4%;text-align:center}.ac-td-time-10{min-width:82px;width:4.4%;text-align:center}.ac-td-date{min-width:100px;width:8%;text-align:center;background-color:#f8fafc}.ac-check-time{display:inline-block;background:#e0f2fe;color:#0369a1;padding:3px 6px;border-radius:4px;font-weight:500;font-size:11px;white-space:nowrap}.ac-check-date{display:inline-block;background:#fef3c7;color:#92400e;padding:4px 6px;border-radius:4px;font-weight:600;font-size:11px}.ac-no-check{color:#9ca3af;font-weight:500}.ac-no-data{text-align:center;padding:40px;color:#6b7280;font-style:italic;font-size:16px}.ac-machine-ip{font-family:Courier New,monospace;font-size:12px;background:rgba(76,175,80,.1);border:1px solid rgba(76,175,80,.3);border-radius:4px;padding:4px 8px;color:#2e7d32;font-weight:500;display:inline-block}@media (max-width: 1400px){.ac-filter-grid{flex-wrap:nowrap}.ac-filter-item{min-width:220px}.ac-stats-bar{flex-wrap:wrap;gap:15px}.ac-stats-desktop .ac-stat-date-picker{min-width:250px}.ac-stat-item{min-width:150px}}@media (max-width: 1024px){.ac-header{flex-direction:column;align-items:stretch;gap:20px}.ac-header-controls{justify-content:space-between}.ac-filter-grid{flex-wrap:nowrap;overflow-x:auto;padding-bottom:10px}.ac-filter-row{display:contents}.ac-filter-item{min-width:200px}.ac-stats-bar{flex-wrap:wrap;justify-content:center;gap:15px}.ac-stat-item{min-width:180px;background:#f8fafc;border:2px solid #e2e8f0;border-radius:10px;padding:15px;transition:all .3s ease}.ac-stat-item:hover:not(.ac-stat-filter){background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-1px);box-shadow:0 2px 10px #0000001a}.ac-stats-desktop{display:none}.ac-stats-mobile{display:flex;flex-direction:column;gap:15px}.ac-stats-mobile .ac-stat-date-picker{flex:1 1 100%;order:1;min-width:100%}.ac-stats-mobile .ac-stats-mobile-row{display:flex;gap:15px;order:2}.ac-attendance-table th{padding:10px 6px;font-size:12px}.ac-attendance-table td{padding:8px 4px;font-size:12px}.td-name{padding-left:8px!important;padding-right:4px!important}.ac-data-table-container{overflow-x:auto;max-height:60vh}.ac-attendance-table{min-width:1000px}}@media (max-width: 768px){.ac-wrapper{padding:8px}.ac-header,.ac-filter-panel,.ac-stats-bar{padding:15px 18px;width:100%;box-sizing:border-box}.ac-page-title h1{font-size:24px}.ac-header-controls{flex-wrap:wrap;gap:10px}.ac-mobile-filter-btn{display:flex!important}.ac-filter-grid{display:flex;flex-direction:column;gap:12px;align-items:stretch;width:100%;box-sizing:border-box}.ac-filter-row{display:flex!important;gap:12px;width:100%;box-sizing:border-box}.ac-filter-row-1{display:flex;gap:8px}.ac-filter-row-1 .ac-filter-item{flex:1;min-width:0;max-width:50%}.ac-filter-row-2{display:flex;gap:8px}.ac-filter-row-2 .ac-filter-item{flex:1;min-width:0;max-width:50%}.ac-filter-row-3{display:flex;gap:8px;align-items:end}.ac-filter-row-3 .ac-filter-item{flex:2;min-width:0}.ac-filter-row-3 .ac-filter-actions{flex:1;display:flex;align-items:end;min-width:0}.ac-filter-row-3 .ac-clear-filters-btn{padding:12px 16px;font-size:14px;white-space:nowrap;min-height:44px;width:100%;display:flex;align-items:center;justify-content:center}.ac-filter-item{min-width:0;max-width:100%;box-sizing:border-box}.ac-filter-actions{margin-left:unset;margin-top:0;max-width:100%;box-sizing:border-box}.ac-stats-bar{flex-direction:column;gap:1px;padding:18px;width:100%;box-sizing:border-box}.ac-stats-mobile-row{display:flex!important;width:100%;gap:10px;box-sizing:border-box}.ac-stat-date-picker{order:1;width:100%;display:flex;flex-direction:column;align-items:center;text-align:center;padding-bottom:15px;border-bottom:1px solid #e5e7eb;background:none!important;border:none!important}.ac-stat-date-picker .ac-stat-label{margin-bottom:10px;font-size:15px;font-weight:600}.ac-stat-date-picker .ac-date-range-picker{background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:8px 12px;width:100%;max-width:350px;min-width:280px;justify-content:center;box-sizing:border-box}.ac-stat-date-picker .ac-date-input{max-width:100px;min-width:80px;font-size:13px;font-weight:600;text-align:center;box-sizing:border-box}.ac-stat-date-picker .ac-date-separator{font-size:16px;margin:0 6px}.ac-stats-mobile-row .ac-stat-item{flex:1;display:flex;flex-direction:column;align-items:center;text-align:center;background:#f8fafc;border:2px solid #e2e8f0;border-radius:12px;padding:12px 6px;transition:all .3s ease;min-width:0;box-sizing:border-box}.ac-stats-mobile-row .ac-stat-item:hover{background:#f1f5f9;border-color:#cbd5e1;transform:translateY(-2px);box-shadow:0 4px 15px #0000001a}.ac-stats-mobile-row .ac-stat-item .ac-stat-label{font-size:12px;font-weight:600;color:#6b7280;margin-bottom:6px;line-height:1.3}.ac-stats-mobile-row .ac-stat-item .ac-stat-value{font-size:20px;font-weight:700;line-height:1.2}.ac-stat-filter{display:none}.ac-data-table-container{max-height:50vh;overflow-x:auto;overflow-y:hidden;display:block}.ac-attendance-table{min-width:1200px;display:table;width:auto}.ac-attendance-table thead{display:table-header-group;position:sticky;top:0;z-index:10;padding-right:0}.ac-attendance-table thead tr{display:table-row;width:auto}.ac-attendance-table tbody{display:table-row-group;overflow:visible;max-height:none;width:auto}.ac-attendance-table tbody tr{display:table-row;width:auto}.ac-attendance-table th,.ac-attendance-table td{padding:6px 3px;font-size:11px;width:auto;min-width:unset}.td-name{padding-left:6px!important;padding-right:3px!important}.ac-th-stt,.ac-td-stt{width:50px}.ac-th-employee-code,.td-employee-code{width:100px}.ac-th-name,.td-name{width:200px}.ac-th-department,.td-department{width:100px}.ac-th-workshop,.td-workshop{width:80px}.ac-th-machine,.td-machine{width:120px}.ac-th-date,.ac-td-date{width:80px}.ac-th-count,.td-count{width:60px}.ac-th-time-1,.ac-th-time-2,.ac-th-time-3,.ac-th-time-4,.ac-th-time-5,.ac-th-time-6,.ac-th-time-7,.ac-th-time-8,.ac-th-time-9,.ac-th-time-10,.ac-td-time,.ac-td-time-10{width:70px}}@media (max-width: 480px){.ac-wrapper{padding:5px}.ac-page-title{flex-direction:row;align-items:center;gap:6px}.ac-page-title h1{font-size:18px}.ac-update-info{flex-direction:column;align-items:flex-start;gap:8px}.ac-header-controls{flex-direction:column;align-items:stretch}.ac-stats-bar{padding:15px;gap:12px}.ac-stats-desktop{display:none}.ac-stats-mobile{display:flex;flex-direction:column;gap:12px}.ac-stat-date-picker .ac-date-range-picker{display:flex;align-items:center;max-width:320px;min-width:260px;padding:8px 12px;gap:8px}.ac-stat-date-picker .ac-calendar-icon{width:16px;height:16px;flex-shrink:0;color:#6b7280}.ac-stat-date-picker .ac-date-inputs{display:flex;align-items:center;gap:8px;flex:1}.ac-stat-date-picker .ac-date-input{flex:1;max-width:none;min-width:80px;font-size:12px;text-align:center}.ac-stat-date-picker .ac-date-separator{font-size:14px;margin:0;flex-shrink:0}.ac-stats-mobile-row{gap:8px}.ac-pagination-footer{flex-direction:column;gap:12px;padding:12px 15px;max-width:100%;box-sizing:border-box}.ac-pagination-info{flex-direction:column;text-align:center;gap:8px;width:100%}.ac-items-per-page{justify-content:center;flex-wrap:wrap}.ac-page-size-select{min-width:100px;font-size:12px}.ac-pagination-controls{flex-direction:column;gap:10px;width:100%;align-items:center}.ac-pagination-pages{flex-wrap:wrap;justify-content:center;gap:4px}.ac-pagination-btn{padding:6px 10px;font-size:12px;min-width:36px}.ac-pagination-jump{justify-content:center;font-size:12px}.ac-page-jump-input{width:50px;font-size:12px}.ac-stats-mobile-row .ac-stat-item{padding:10px 6px}.ac-stats-mobile-row .ac-stat-item .ac-stat-label{font-size:11px;margin-bottom:4px}.ac-stats-mobile-row .ac-stat-item .ac-stat-value{font-size:18px}.ac-filter-row-1,.ac-filter-row-2{gap:8px}.ac-filter-row-3{flex-direction:column;gap:8px;align-items:stretch}.ac-filter-row-3 .ac-filter-item{flex:none;width:100%}.ac-filter-row-3 .ac-filter-actions{flex:none;width:100%;flex-direction:column;gap:6px}.ac-clear-filters-btn,.ac-export-excel-btn{width:100%;justify-content:center;padding:10px 14px;min-height:42px;font-size:13px}.ac-filter-toggle-btn,.ac-auto-refresh-btn,.ac-manual-refresh-btn{justify-content:center}.ac-attendance-table th,.ac-attendance-table td{padding:4px 2px;font-size:10px}.td-name{padding-left:4px!important;padding-right:2px!important}.ac-employee-code,.ac-fingerprint-code,.ac-check-count,.ac-check-time,.ac-check-date,.ac-machine-ip{padding:2px 4px;font-size:9px}}@media (max-width: 460px){.ac-wrapper{padding:5px}.ac-header,.ac-filter-panel,.ac-stats-bar{padding:12px;margin-bottom:8px;width:100%;box-sizing:border-box}.ac-stats-desktop{display:none}.ac-stats-mobile{display:flex;flex-direction:column;gap:8px}.ac-page-title{flex-direction:row;align-items:center;gap:6px}.ac-page-title h1{font-size:20px}.ac-title-icon{width:24px;height:24px;flex-shrink:0}.ac-stats-bar{gap:8px}.ac-stat-date-picker .ac-date-range-picker{display:flex;align-items:center;width:100%;max-width:280px;min-width:240px;padding:6px 10px;gap:6px;box-sizing:border-box}.ac-stat-date-picker .ac-calendar-icon{width:14px;height:14px;flex-shrink:0;color:#6b7280}.ac-stat-date-picker .ac-date-inputs{display:flex;align-items:center;gap:6px;flex:1;min-width:0}.ac-stat-date-picker .ac-date-input{flex:1;min-width:60px;font-size:10px;text-align:center;padding:2px}.ac-stat-date-picker .ac-date-separator{font-size:10px;margin:0;flex-shrink:0}.ac-pagination-footer{flex-direction:column;gap:10px;padding:10px 12px;max-width:100%;box-sizing:border-box}.ac-pagination-info{flex-direction:column;text-align:center;gap:6px;width:100%;font-size:12px}.ac-items-per-page{justify-content:center;flex-wrap:wrap;gap:6px}.ac-page-size-select{min-width:90px;font-size:11px;padding:6px 8px}.ac-pagination-controls{flex-direction:column;gap:8px;width:100%;align-items:center}.ac-pagination-pages{flex-wrap:wrap;justify-content:center;gap:2px;max-width:100%}.ac-pagination-btn{padding:5px 8px;font-size:11px;min-width:32px}.ac-pagination-jump{justify-content:center;font-size:11px;gap:6px}.ac-page-jump-input{width:45px;font-size:11px;padding:4px 6px}.ac-filter-grid{gap:6px}.ac-filter-row-1,.ac-filter-row-2{gap:4px}.ac-filter-row-3{gap:4px;flex-direction:column;align-items:stretch}.ac-filter-row-3 .ac-filter-item,.ac-filter-row-3 .ac-filter-actions{flex:none;width:100%;max-width:100%;box-sizing:border-box}.ac-filter-row-3 .ac-filter-actions{flex-direction:column;gap:4px}.ac-clear-filters-btn,.ac-export-excel-btn{padding:8px 10px;min-height:36px;font-size:12px;width:100%;box-sizing:border-box}}@media (max-width: 380px){.ac-page-title{flex-direction:row;align-items:center;gap:4px}.ac-page-title h1{font-size:16px}.ac-title-icon{width:20px;height:20px;flex-shrink:0}.ac-stats-desktop{display:none}.ac-stats-mobile{display:flex;flex-direction:column;gap:6px}.ac-stat-date-picker .ac-date-range-picker{display:flex;align-items:center;max-width:260px;min-width:220px;padding:6px 8px;gap:4px}.ac-stat-date-picker .ac-calendar-icon{width:12px;height:12px;flex-shrink:0}.ac-stat-date-picker .ac-date-inputs{display:flex;align-items:center;gap:4px;flex:1}.ac-stat-date-picker .ac-date-input{flex:1;min-width:60px;font-size:10px;text-align:center;padding:2px}.ac-stat-date-picker .ac-date-separator{font-size:10px;margin:0;flex-shrink:0}.ac-pagination-footer{flex-direction:column;gap:8px;padding:8px 10px;max-width:100%;box-sizing:border-box}.ac-pagination-info{flex-direction:column;text-align:center;gap:4px;width:100%;font-size:11px}.ac-items-per-page{justify-content:center;flex-wrap:wrap;gap:4px}.ac-items-per-page label{font-size:10px}.ac-page-size-select{min-width:80px;font-size:10px;padding:4px 6px}.ac-pagination-controls{flex-direction:column;gap:6px;width:100%;align-items:center}.ac-pagination-pages{flex-wrap:wrap;justify-content:center;gap:1px;max-width:100%}.ac-pagination-btn{padding:4px 6px;font-size:10px;min-width:28px}.ac-pagination-jump{justify-content:center;font-size:10px;gap:4px}.ac-page-jump-input{width:40px;font-size:10px;padding:3px 4px}.ac-filter-grid{gap:6px}.ac-filter-row-1,.ac-filter-row-2{gap:4px}.ac-filter-row-3{gap:4px;flex-direction:column;align-items:stretch}.ac-filter-row-3 .ac-filter-item,.ac-filter-row-3 .ac-filter-actions{flex:none;width:100%;max-width:100%;box-sizing:border-box}.ac-filter-row-3 .ac-filter-actions{flex-direction:column;gap:4px}.ac-clear-filters-btn,.ac-export-excel-btn{padding:8px 10px;min-height:36px;font-size:12px;width:100%;box-sizing:border-box}}.ie-import-export-container{height:calc(100vh - 60px);width:100%;margin:5px;max-width:calc(100vw - 70px);background-color:#f9fafb;overflow:hidden;box-sizing:border-box;display:flex;flex-direction:column}.ie-import-export-wrapper{margin:0 auto;max-width:100vw;width:100%;box-sizing:border-box;flex:1;display:flex;flex-direction:column;overflow:hidden}.ie-main-content{display:flex;flex-direction:column;gap:1.5rem;padding:1.5rem;width:100%;max-width:100%;box-sizing:border-box;flex:1;overflow-y:auto}.ie-export-mode .ie-import-export-wrapper{overflow:hidden}.ie-export-mode .ie-main-content{overflow:hidden;padding:0}@media (max-width: 768px){.ie-import-export-wrapper{max-width:100vw}.ie-main-content{padding:1rem}}.ie-export-layout{display:flex;flex-direction:row;gap:.5rem;width:100%;max-width:100%;box-sizing:border-box;flex:1;overflow:hidden}.ie-export-sidebar{width:300px;min-width:300px;flex-shrink:0;display:flex;flex-direction:column;height:100%}.ie-export-content{flex:1;display:flex;flex-direction:column;min-width:0;height:100%;overflow:hidden}.ie-export-sidebar-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;padding:.5rem;height:100%;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column}.ie-export-sidebar .ie-form-grid,.ie-export-sidebar .ie-date-range-container{grid-template-columns:1fr;gap:1rem}.ie-export-sidebar .ie-date-range-container.ie-extended-filters{grid-template-columns:1fr}.ie-preview-header-actions{display:flex;gap:.5rem;align-items:flex-start;flex-shrink:0}.ie-preview-header-content{flex:1;min-width:0}.ie-preview-header-actions .ie-action-button{width:auto;min-width:120px;padding:.5rem 1rem;font-size:.875rem;white-space:nowrap}@media (max-width: 1024px){.ie-export-layout{flex-direction:column;height:auto;min-height:calc(100vh - 200px)}.ie-export-sidebar{width:100%;min-width:auto;height:auto}.ie-export-sidebar-card{height:auto;overflow:visible}.ie-export-content,.ie-data-preview{height:auto}.ie-preview-header{flex-direction:column;align-items:stretch;gap:1rem}.ie-preview-header-actions{width:100%;justify-content:flex-start}.ie-preview-header-actions .ie-action-button{flex:1;min-width:auto}}@media (max-width: 768px){.ie-export-layout{height:auto;padding:.5rem}.ie-data-table-wrapper{overflow-x:auto;overflow-y:visible}.ie-preview-header-actions{flex-direction:column}.ie-preview-header-actions .ie-action-button{width:100%}}.ie-export-mode,.ie-export-mode body,.ie-export-mode html,.ie-export-mode .ie-import-export-wrapper,.ie-export-mode .ie-export-layout,.ie-export-mode .ie-main-content{overflow:hidden!important}body:has(.ie-export-mode),html:has(.ie-export-mode){overflow:hidden!important}.page-header{margin-bottom:2rem}.page-title{font-size:1.875rem;font-weight:700;color:#111827;margin-bottom:.5rem}.page-description{color:#6b7280}.ie-message-container{margin-bottom:1.5rem;padding:1rem;border-radius:.5rem;border:1px solid}.ie-error-message{background-color:#fef2f2;border-color:#fecaca;color:#dc2626}.ie-success-message{background-color:#f0fdf4;border-color:#bbf7d0;color:#166534}.ie-message-content{display:flex;align-items:center}.ie-message-icon{width:1.25rem;height:1.25rem;margin-right:.5rem}.ie-tab-navigation{display:flex;width:100%;background:#f8fafc;border-bottom:2px solid #e2e8f0;flex-shrink:0}.ie-tab-button{flex:1;display:flex;align-items:center;justify-content:center;padding:1rem 2rem;font-size:1rem;font-weight:600;color:#64748b;background:transparent;border:none;cursor:pointer;transition:all .3s ease;position:relative}.ie-tab-button:hover{background:#f1f5f9;color:#475569}.ie-tab-button.active{color:#2563eb;background:#ffffff;border-bottom:3px solid #2563eb}.ie-tab-button.active:after{content:"";position:absolute;bottom:-2px;left:0;right:0;height:3px;background:#2563eb}.ie-tab-icon{width:1.25rem;height:1.25rem;margin-right:.5rem}@media (max-width: 640px){.ie-tab-button{padding:.75rem 1rem;font-size:.875rem}.ie-tab-icon{width:1rem;height:1rem}}.mode-selector{margin-bottom:1.5rem}.mode-buttons{display:flex;gap:1rem}.mode-button{display:flex;align-items:center;padding:.75rem 1.5rem;border-radius:.5rem;font-weight:500;transition:all .2s;cursor:pointer;border:none;outline:none}.mode-button-icon{width:1.25rem;height:1.25rem;margin-right:.5rem}.mode-button.active-import{background-color:#2563eb;color:#fff}.mode-button.active-export{background-color:#059669;color:#fff}.mode-button.inactive{background-color:#f3f4f6;color:#374151}.mode-button.inactive:hover{background-color:#e5e7eb}@media (max-width: 768px){.mode-buttons{flex-direction:column}}.ie-table-selector{width:100%;max-width:100%}.ie-form-label{display:block;font-size:.875rem;font-weight:500;color:#374151;margin-bottom:.5rem}.ie-form-select,.ie-form-input{width:100%;max-width:100%;padding:.75rem;border:1px solid #d1d5db;border-radius:.375rem;outline:none;transition:all .2s;box-sizing:border-box}.ie-form-select:focus,.ie-form-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.ie-form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;margin-bottom:1.5rem;width:100%;max-width:100%;box-sizing:border-box}.ie-date-filter-section{margin:0;padding:1rem;background-color:#f8fafc;border-radius:.5rem;border:1px solid #e5e7eb;width:100%;max-width:100%;box-sizing:border-box}.ie-filter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;flex-wrap:wrap;gap:.5rem}.ie-filter-controls{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.ie-preview-limit-control{display:flex;align-items:center;gap:.5rem}.ie-inline-label{margin-bottom:0;font-size:.875rem;white-space:nowrap}.ie-compact-select{min-width:120px;padding:.5rem;font-size:.875rem}.ie-filter-title{font-size:1rem;font-weight:600;color:#374151;margin:0}.ie-filter-indicator{font-size:.75rem;font-weight:500;color:#059669;opacity:.8}.ie-clear-filters-button{display:flex;align-items:center;padding:.5rem 1rem;font-size:.875rem;font-weight:500;color:#374151;background-color:#fff;border:1px solid #d1d5db;border-radius:.375rem;cursor:pointer;transition:all .2s}.ie-clear-filters-button:hover:not(:disabled){background-color:#f9fafb;border-color:#9ca3af}.ie-clear-filters-button:disabled{opacity:.5;cursor:not-allowed}.ie-checkbox-container{margin-bottom:1rem;width:100%}.ie-checkbox-label{display:flex;align-items:center;cursor:pointer;font-weight:500;color:#374151;flex-wrap:wrap}.ie-checkbox-input{width:1.125rem;height:1.125rem;margin-right:.5rem;cursor:pointer;accent-color:#2563eb;flex-shrink:0}.ie-checkbox-text{font-size:.875rem;flex:1}.ie-date-range-container{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem;width:100%;max-width:100%}.ie-date-range-container.ie-extended-filters{grid-template-columns:1fr;gap:1rem}@media (min-width: 1024px){.ie-date-range-container.ie-extended-filters:not(.ie-export-sidebar .ie-date-range-container){grid-template-columns:repeat(3,1fr)}}@media (min-width: 1280px){.ie-date-range-container.ie-extended-filters:not(.ie-export-sidebar .ie-date-range-container){grid-template-columns:repeat(4,1fr)}}.ie-date-input-group{display:flex;flex-direction:column;width:100%;max-width:100%}.ie-date-input{font-size:.875rem;box-sizing:border-box}.ie-filter-count{font-size:.75rem;color:#6b7280;font-weight:400;opacity:.8}@media (max-width: 768px){.ie-form-grid,.ie-date-range-container{grid-template-columns:1fr}.ie-date-filter-section{margin:0;padding:.75rem}.ie-filter-header{flex-direction:column;align-items:flex-start;gap:.75rem}.ie-filter-controls{width:100%;flex-direction:column;align-items:stretch}.ie-preview-limit-control{width:100%;justify-content:space-between}.ie-compact-select{flex:1;max-width:140px}.ie-clear-filters-button{width:100%;justify-content:center}.ie-checkbox-label{align-items:flex-start}.ie-checkbox-input{margin-top:.125rem}}.ie-section-card{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;width:100%;max-width:100%;box-sizing:border-box;padding:1.5rem}.ie-section-header{font-size:1.25rem;font-weight:700;color:#111827;margin-bottom:1rem;display:flex;align-items:center;word-wrap:break-word}.ie-section-icon{width:1.5rem;height:1.5rem;margin-right:.5rem;flex-shrink:0}.ie-section-icon.ie-import{color:#2563eb}.ie-section-icon.ie-export{color:#059669}.ie-file-upload-area{border:2px dashed #d1d5db;border-radius:.5rem;padding:1.5rem;text-align:center;transition:border-color .2s;margin-bottom:1rem;cursor:pointer}.ie-file-upload-area:hover{border-color:#3b82f6}.ie-file-input{display:none}.ie-file-select-button{display:inline-flex;align-items:center;padding:.5rem 1rem;background-color:#2563eb;color:#fff;border-radius:.375rem;border:none;cursor:pointer;transition:background-color .2s}.ie-file-select-button:hover{background-color:#1d4ed8}.ie-file-info{margin-top:1rem;font-size:.875rem;color:#6b7280}.ie-file-name{font-weight:500}.ie-action-button{width:100%;display:inline-flex;align-items:center;justify-content:center;padding:.75rem 1.5rem;border-radius:.375rem;font-weight:500;border:none;cursor:pointer;transition:all .2s;outline:none}.ie-action-button:disabled{opacity:.5;cursor:not-allowed}.ie-action-button.ie-import{background-color:#059669;color:#fff}.ie-action-button.ie-import:hover:not(:disabled){background-color:#047857}.ie-action-button.ie-export{background-color:#059669;color:#fff}.ie-action-button.ie-export:hover:not(:disabled){background-color:#047857}.ie-action-button.ie-secondary{background-color:#6b7280;color:#fff}.ie-action-button.ie-secondary:hover:not(:disabled){background-color:#4b5563}.ie-loading-spinner{width:1.25rem;height:1.25rem;border:2px solid transparent;border-top:2px solid currentColor;border-radius:50%;animation:ie-spin 1s linear infinite;margin-right:.5rem}@keyframes ie-spin{to{transform:rotate(360deg)}}.ie-data-preview{background-color:#fff;border-radius:.5rem;box-shadow:0 1px 3px #0000001a;width:100%;max-width:100%;box-sizing:border-box;height:100%;display:flex;flex-direction:column;overflow:hidden}.ie-preview-header{padding:1rem;border-bottom:1px solid #e5e7eb;box-sizing:border-box;display:flex;justify-content:space-between;align-items:flex-start;gap:1rem;flex-shrink:0}.ie-preview-title{font-size:1.125rem;font-weight:600;color:#111827;display:flex;align-items:center;margin-bottom:.5rem;word-wrap:break-word}.ie-preview-description{color:#6b7280;font-size:.875rem;width:100%;max-width:100%}.ie-preview-description p{margin:.25rem 0;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word}.ie-preview-description strong{color:#374151;font-weight:600}.ie-data-table-wrapper{overflow-x:auto;overflow-y:auto;max-width:100%;width:100%;flex:1}.ie-data-preview-content{display:flex;flex-direction:column;flex:1;min-height:0;overflow:hidden}.ie-data-table{width:100%;border-collapse:collapse;table-layout:auto}.ie-export-content .ie-data-preview{max-height:100%}.ie-table-header{background-color:#f9fafb}.ie-table-header th{padding:.75rem 1rem;text-align:left;font-size:.75rem;font-weight:500;color:#6b7280;text-transform:uppercase;letter-spacing:.05em;border-bottom:1px solid #e5e7eb}.ie-table-body{background-color:#fff}.ie-table-body td{padding:.75rem 1rem;font-size:.875rem;color:#111827;border-bottom:1px solid #e5e7eb}.ie-table-body tr:hover{background-color:#f9fafb}.ie-pagination-container{padding:1rem 1.5rem;border-top:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background-color:#fff}.ie-pagination-info{display:flex;align-items:center;gap:.5rem}.ie-pagination-text{font-size:.875rem;color:#374151}.ie-pagination-select{padding:.25rem .5rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem}.ie-pagination-controls{display:flex;align-items:center;gap:.5rem}.ie-pagination-button{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:.25rem;font-size:.875rem;cursor:pointer;transition:all .2s}.ie-pagination-button:hover:not(:disabled){background-color:#f9fafb}.ie-pagination-button:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.ie-pagination-container{flex-direction:column;gap:1rem}}.dktv-page .dktv-container{max-width:100%;margin:0 auto;background:#f8f9fa;height:calc(100vh - 50px);display:flex;flex-direction:column;overflow:hidden}.dktv-page .dktv-loading{display:flex;align-items:center;justify-content:center;min-height:400px;font-size:16px;color:#6c757d}.dktv-page .dktv-error{padding:20px;background:#f8d7da;color:#721c24;border:1px solid #f5c6cb;border-radius:6px;margin:20px;text-align:center}.dktv-page .results-info{flex-shrink:0;background:white;padding:15px 20px;border-radius:6px;font-size:14px;color:#6c757d;box-shadow:0 1px 3px #0000001a;display:flex;align-items:center;justify-content:space-between;gap:15px}.dktv-page .results-text{flex:1}.dktv-page .search-results-indicator{color:#007bff;font-weight:600;margin-right:5px}.dktv-page .contract-type{margin:4px 0}.dktv-page .contract-badge{display:inline-block;padding:2px 8px;border-radius:12px;font-size:11px;font-weight:500;text-transform:uppercase;letter-spacing:.5px}.dktv-page .contract-seasonal{background-color:#e3f2fd;color:#1976d2;border:1px solid #bbdefb}.dktv-page .contract-intern{background-color:#f3e5f5;color:#7b1fa2;border:1px solid #ce93d8}.dktv-page .candidate-avatar{width:40px;height:40px;border-radius:50%;-o-object-fit:cover;object-fit:cover;border:2px solid #dee2e6}.dktv-page .no-avatar{width:40px;height:40px;border-radius:50%;background:#e9ecef;display:flex;align-items:center;justify-content:center;font-size:10px;color:#6c757d;border:2px solid #dee2e6;margin:0 auto}.dktv-page .large-avatar{width:120px;height:180px;border-radius:8px;-o-object-fit:cover;object-fit:cover;border:2px solid #dee2e6}.dktv-page .no-large-avatar{width:120px;height:180px;background:#e9ecef;border:2px solid #dee2e6;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:14px;color:#6c757d}.dktv-page .text-center{text-align:center!important;justify-content:center!important}.dktv-page .candidate-name{font-weight:600;color:#495057}.dktv-page .candidate-info{font-size:13px;line-height:1.4}.dktv-page .candidate-info>div{margin-bottom:4px}.dktv-page .candidate-info>div:last-child{margin-bottom:0}.dktv-page .register-time{font-size:12px;color:#6c757d;font-style:italic;text-align:right;width:100%}.dktv-page .status-badge{padding:6px 12px;border-radius:4px;font-size:16px;font-weight:500;text-align:left;display:inline-block;width:auto;max-width:-moz-fit-content;max-width:fit-content}.dktv-page .status-pending{background:#fff3cd;color:#856404;border:1px solid #ffeaa7}.dktv-page .status-approved{background:#d4edda;color:#155724;border:1px solid #c3e6cb}.dktv-page .status-rejected{background:#f8d7da;color:#721c24;border:1px solid #f5c6cb}.dktv-page .readonly-input{background-color:#f8f9fa!important;cursor:not-allowed!important;color:#6c757d;border:1px solid #dee2e6;font-weight:500}.dktv-page .readonly-input:focus{outline:none;box-shadow:0 0 0 2px #667eea40;border-color:#667eea}.dktv-page .desktop-table{display:table}@media (max-width: 768px){.dktv-page .results-info{flex-direction:column;align-items:flex-start;gap:10px}.dktv-page .results-text{width:100%}.dktv-page .clear-all-filters-btn{align-self:flex-end}}.dktv-page .dktv-header{flex-shrink:0;background:white;padding:20px;border-radius:8px;box-shadow:0 2px 4px #0000001a}.dktv-page .dktv-header h2{margin:0 0 20px;color:#2c3e50;font-size:24px;font-weight:600}.dktv-page .dktv-controls{display:flex;gap:15px;align-items:center;flex-wrap:wrap}.dktv-page .add-candidate-btn{display:flex;align-items:center;gap:8px;padding:10px 16px;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s;white-space:nowrap}.dktv-page .add-candidate-btn:hover{background:#218838}.dktv-page .clear-all-filters-btn{display:flex;align-items:center;gap:6px;padding:8px 12px;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:13px;font-weight:500;cursor:pointer;transition:background-color .3s;white-space:nowrap}.dktv-page .clear-all-filters-btn:hover{background:#c82333}@media (max-width: 768px){.dktv-page .dktv-header{padding:8px 0;box-shadow:none;border-radius:0;background:white}.dktv-page .dktv-header h2{display:none!important}.dktv-page .dktv-controls{display:flex!important;flex-direction:row!important;align-items:center!important;gap:8px!important;width:100%!important;padding:0!important;justify-content:space-between!important}.dktv-page .add-candidate-btn{min-width:40px!important;max-width:40px!important;height:40px!important;padding:0!important;justify-content:center!important;background:#28a745!important;border-radius:6px!important;color:transparent!important;display:flex!important;align-items:center!important;gap:0!important;flex-shrink:0!important;overflow:hidden!important;white-space:nowrap!important;position:relative!important}.dktv-page .add-candidate-btn>svg{width:24px!important;height:24px!important;color:#fff!important;flex-shrink:0!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.dktv-page .nha-thoi-vu-filter-mobile-btn{display:flex!important;min-width:40px!important;max-width:40px!important;height:40px!important;background:#fff!important;border:1px solid #ddd!important;border-radius:6px!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;margin-left:0!important;color:#667eea!important;transition:all .3s ease!important;flex-shrink:0!important}.dktv-page .nha-thoi-vu-filter-mobile-btn:hover{background:rgba(102,126,234,.1)!important;border-color:#667eea!important}.dktv-page .nha-thoi-vu-filter-mobile-btn>svg{width:22px!important;height:22px!important;color:#667eea!important}}.dktv-page .date-filter-container{display:flex;align-items:center;gap:8px;flex-shrink:0}.dktv-page .date-filter-inputs{display:flex;align-items:center;gap:8px;padding:6px 10px;background:white;border:1px solid #ddd;border-radius:6px;min-width:280px}.dktv-page .date-filter-input{border:none;outline:none;font-size:13px;color:#333;background:transparent;min-width:100px}.dktv-page .date-separator{font-size:12px;color:#666;margin:0 4px;white-space:nowrap}.dktv-page .clear-date-filter-btn{display:flex;align-items:center;justify-content:center;width:20px;height:20px;background:#dc3545;color:#fff;border:none;border-radius:3px;cursor:pointer;transition:background-color .2s;margin-left:4px}.dktv-page .clear-date-filter-btn:hover{background:#c82333}.dktv-page .date-filter-mobile-btn{display:none;position:relative}.dktv-page .date-filter-mobile-btn.has-filter{background:rgba(40,167,69,.1)!important;border-color:#28a745!important;color:#28a745!important}.dktv-page .filter-indicator{position:absolute;top:-2px;right:-2px;width:8px;height:8px;background:#28a745;border-radius:50%;font-size:16px;font-weight:700}.dktv-page .date-filter-modal-mobile{z-index:1000}.dktv-page .date-filter-modal-content-mobile{background:white;border-radius:8px;max-width:350px;width:90%;max-height:90vh;overflow:hidden;box-shadow:0 4px 20px #00000026}.dktv-page .date-filter-modal-header{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid #eee;background:#f8f9fa}.dktv-page .date-filter-modal-header h4{margin:0;font-size:16px;color:#333;font-weight:600}.dktv-page .date-filter-modal-close-mobile{background:none;border:none;font-size:20px;color:#666;cursor:pointer;padding:4px;display:flex;align-items:center;justify-content:center}.dktv-page .date-filter-modal-body{padding:20px}.dktv-page .date-filter-mobile-inputs{display:flex;flex-direction:column;gap:16px;margin-bottom:20px}.dktv-page .date-input-group{display:flex;flex-direction:column;gap:6px}.dktv-page .date-input-group label{font-size:14px;font-weight:500;color:#333}.dktv-page .date-filter-input-mobile{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;color:#333;outline:none}.dktv-page .date-filter-input-mobile:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.dktv-page .date-filter-mobile-actions{display:flex;gap:10px;justify-content:space-between}.dktv-page .clear-date-mobile-btn{flex:1;padding:10px 16px;background:#6c757d;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.dktv-page .clear-date-mobile-btn:hover{background:#5a6268}.dktv-page .apply-date-mobile-btn{flex:1;padding:10px 16px;background:#28a745;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.dktv-page .apply-date-mobile-btn:hover{background:#218838}@media (max-width: 768px){.dktv-page .desktop-date-filter{display:none!important}.dktv-page .date-filter-mobile-btn{display:flex!important;min-width:40px!important;max-width:40px!important;height:40px!important;background:#fff!important;border:1px solid #ddd!important;border-radius:6px!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;color:#667eea!important;transition:all .3s ease!important;flex-shrink:0!important}.dktv-page .date-filter-mobile-btn:hover{background:rgba(102,126,234,.1)!important;border-color:#667eea!important}.dktv-page .date-filter-mobile-btn>svg{width:22px!important;height:22px!important;color:#667eea!important}}.dktv-page .search-container{position:relative;flex:1;min-width:300px}.dktv-page .search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#6c757d;transition:all .3s ease}.search-icon.searching{color:#007bff;animation:searching-pulse 1.5s infinite}@keyframes searching-pulse{0%,to{opacity:.5;transform:translateY(-50%) scale(1)}50%{opacity:1;transform:translateY(-50%) scale(1.1)}}.dktv-page .search-input{width:100%;padding:10px 60px 10px 40px;border:1px solid #ddd;border-radius:6px;font-size:14px;transition:border-color .3s}.dktv-page .search-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.dktv-page .search-button{position:absolute;right:35px;top:50%;transform:translateY(-50%);background:#007bff;color:#fff;border:none;border-radius:4px;padding:6px 8px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;min-width:28px;height:28px}.dktv-page .search-button:hover:not(:disabled){background:#0056b3;transform:translateY(-50%) scale(1.05)}.dktv-page .search-button:disabled{background:#6c757d;cursor:not-allowed}.dktv-page .search-button.searching{background:#28a745}.dktv-page .search-spinner{width:14px;height:14px;border:2px solid transparent;border-top:2px solid white;border-radius:50%;animation:spin 1s linear infinite}.dktv-page .clear-search-button{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:#dc3545;color:#fff;border:none;border-radius:50%;padding:4px;cursor:pointer;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:22px;height:22px;font-size:12px;line-height:1}.dktv-page .clear-search-button:hover{background:#c82333;transform:translateY(-50%) scale(1.1)}.dktv-page .nha-thoi-vu-filter{padding:10px 12px;border:1px solid #ddd;border-radius:6px;font-size:14px;background:white;min-width:200px;transition:border-color .3s}.dktv-page .nha-thoi-vu-filter:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.dktv-page .nha-thoi-vu-modal-mobile{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:rgba(0,0,0,.3)!important;z-index:2000!important;display:flex!important;align-items:center!important;justify-content:center!important}.dktv-page .nha-thoi-vu-modal-content-mobile{background:#fff!important;border-radius:10px!important;box-shadow:0 2px 12px #00000026!important;padding:16px!important;min-width:220px!important;max-width:90vw!important;max-height:80vh!important;overflow-y:auto!important;position:relative!important}.dktv-page .nha-thoi-vu-modal-content-mobile h4{font-size:1.1rem!important;margin-bottom:12px!important;color:#2c3e50!important}.dktv-page .nha-thoi-vu-modal-list-mobile{list-style:none!important;padding:0!important;margin:0!important}.dktv-page .nha-thoi-vu-modal-list-mobile li{padding:10px 0!important;border-bottom:1px solid #eee!important;cursor:pointer!important;color:#374151!important;font-size:1rem!important;transition:background .2s!important}.dktv-page .nha-thoi-vu-modal-list-mobile li:last-child{border-bottom:none!important}.dktv-page .nha-thoi-vu-modal-list-mobile li:hover,.dktv-page .nha-thoi-vu-modal-list-mobile li.selected{background:#f0f4ff!important;color:#667eea!important}.dktv-page .nha-thoi-vu-modal-close-mobile{position:absolute!important;top:10px!important;right:16px!important;background:none!important;border:none!important;font-size:1.5rem!important;color:#667eea!important;cursor:pointer!important}.dktv-page .nha-thoi-vu-filter-mobile-btn{display:none}@media (max-width: 768px){.dktv-page .app-container{width:100vw;max-width:100vw;margin:0;box-sizing:border-box;padding:0 8px}.dktv-page .nha-thoi-vu-filter-mobile-btn{display:flex!important;min-width:40px!important;max-width:40px!important;height:40px!important;background:#fff!important;border:1px solid #ddd!important;border-radius:6px!important;align-items:center!important;justify-content:center!important;cursor:pointer!important;margin-left:0!important;color:#667eea!important;transition:all .3s ease!important;flex-shrink:0!important}.dktv-page .nha-thoi-vu-filter-mobile-btn:hover{background:rgba(102,126,234,.1)!important;border-color:#667eea!important}.dktv-page .nha-thoi-vu-filter-mobile-btn>svg{width:22px!important;height:22px!important;color:#667eea!important}.dktv-page .nha-thoi-vu-modal-mobile{position:fixed!important;top:0!important;left:0!important;right:0!important;bottom:0!important;background:rgba(0,0,0,.3)!important;z-index:2000!important;display:flex!important;align-items:center!important;justify-content:center!important}.dktv-page .nha-thoi-vu-modal-content-mobile{background:#fff!important;border-radius:10px!important;box-shadow:0 2px 12px #00000026!important;padding:16px!important;min-width:220px!important;max-width:90vw!important;max-height:80vh!important;overflow-y:auto!important;position:relative!important}.dktv-page .nha-thoi-vu-modal-content-mobile h4{font-size:1.1rem!important;margin-bottom:12px!important;color:#2c3e50!important}.dktv-page .nha-thoi-vu-modal-list-mobile{list-style:none!important;padding:0!important;margin:0!important}.dktv-page .nha-thoi-vu-modal-list-mobile li{padding:10px 0!important;border-bottom:1px solid #eee!important;cursor:pointer!important;color:#374151!important;font-size:1rem!important;transition:background .2s!important}.dktv-page .nha-thoi-vu-modal-list-mobile li:last-child{border-bottom:none!important}.dktv-page .nha-thoi-vu-modal-list-mobile li:hover,.dktv-page .nha-thoi-vu-modal-list-mobile li.selected{background:#f0f4ff!important;color:#667eea!important}.dktv-page .nha-thoi-vu-modal-close-mobile{position:absolute!important;top:10px!important;right:16px!important;background:none!important;border:none!important;font-size:1.5rem!important;color:#667eea!important;cursor:pointer!important}}@media (max-width: 768px){.dktv-page .search-container{flex:1!important;min-width:0!important;margin:0!important;max-width:calc(100% - 100px)!important}.dktv-page .search-input{font-size:14px!important;padding:8px 8px 8px 36px!important;border-radius:6px!important;width:100%!important}.dktv-page .nha-thoi-vu-filter{display:none!important}}@media (max-width: 992px){.dktv-page .search-container{min-width:auto}}.dktv-page .candidates-table-container{flex:1;display:flex;flex-direction:column;overflow:hidden;background:white;border-radius:8px;box-shadow:0 2px 4px #0000001a}.dktv-page .candidates-table{width:100%;border-collapse:collapse;font-size:16px}.dktv-page .candidates-table.desktop-table{width:100%;border-collapse:collapse;display:flex;flex-direction:column;height:100%;overflow:hidden}.dktv-page .candidates-table.desktop-table thead{flex-shrink:0;background:#6c757d;color:#fff;padding-right:17px;box-sizing:border-box}.dktv-page .candidates-table.desktop-table thead tr{display:flex}.dktv-page .candidates-table.desktop-table thead th{flex:1;padding:10px 6px;text-align:center;font-weight:600;font-size:14px;border-right:1px solid rgba(255,255,255,.2);min-width:0;height:42px;display:flex;align-items:center;justify-content:center}.dktv-page .candidates-table.desktop-table thead th:last-child{border-right:none}.dktv-page .candidates-table.desktop-table:has(tbody::-webkit-scrollbar) thead{padding-right:17px}@supports not (selector(:has(*))){.dktv-page .candidates-table.desktop-table thead{padding-right:17px}}.dktv-page .candidates-table.desktop-table thead th:nth-child(1){flex:0 0 4%;min-width:40px}.dktv-page .candidates-table.desktop-table thead th:nth-child(2){flex:0 0 11%;min-width:100px}.dktv-page .candidates-table.desktop-table thead th:nth-child(3){flex:0 0 18%;min-width:150px}.dktv-page .candidates-table.desktop-table thead th:nth-child(4){flex:0 0 9%;min-width:85px}.dktv-page .candidates-table.desktop-table thead th:nth-child(5){flex:0 0 7%;min-width:60px}.dktv-page .candidates-table.desktop-table thead th:nth-child(6){flex:0 0 9%;min-width:90px}.dktv-page .candidates-table.desktop-table thead th:nth-child(7){flex:0 0 12%;min-width:100px}.dktv-page .candidates-table.desktop-table thead th:nth-child(8){flex:0 0 9%;min-width:85px}.dktv-page .candidates-table.desktop-table thead th:nth-child(9){flex:0 0 15%;min-width:140px}.dktv-page .candidates-table.desktop-table thead th:nth-child(10){flex:0 0 6%;min-width:70px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(1){flex:0 0 4%;min-width:40px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(2){flex:0 0 11%;min-width:100px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(3){flex:0 0 18%;min-width:150px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(4){flex:0 0 9%;min-width:85px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(5){flex:0 0 7%;min-width:60px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(6){flex:0 0 9%;min-width:90px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(7){flex:0 0 12%;min-width:100px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(8){flex:0 0 9%;min-width:85px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(9){flex:0 0 15%;min-width:140px}.dktv-page .candidates-table.desktop-table tbody td:nth-child(10){flex:0 0 6%;min-width:70px}.dktv-page .candidates-table.desktop-table tbody{flex:1;overflow-y:scroll;overflow-x:hidden;display:block;max-height:calc(100vh - 300px);padding-right:0;box-sizing:content-box;scrollbar-gutter:stable;min-height:calc(100vh - 350px)}.dktv-page .candidates-table.desktop-table tbody tr{display:flex;border-bottom:1px solid #dee2e6;transition:background-color .2s;width:100%;box-sizing:border-box}.dktv-page .candidates-table.desktop-table tbody tr:hover{background-color:#f8f9fa}.dktv-page .candidates-table.desktop-table tbody td{flex:1;padding:8px 6px;text-align:center;vertical-align:middle;border-right:1px solid #dee2e6;min-width:0;word-wrap:break-word;display:flex;align-items:center;justify-content:center;line-height:1.2}.dktv-page .candidates-table.desktop-table tbody td:last-child{border-right:none}.dktv-page .mobile-table{display:none}.dktv-page .candidates-table.mobile-table{width:100%;border-collapse:collapse;table-layout:fixed}.dktv-page .candidates-table.mobile-table thead{background:#6c757d;color:#fff}.dktv-page .candidates-table.mobile-table thead th{padding:10px 8px;text-align:center;font-weight:600;font-size:13px;border-right:1px solid rgba(255,255,255,.2)}.dktv-page .candidates-table.mobile-table thead th:last-child{border-right:none}.dktv-page .candidates-table.mobile-table tbody{display:table-row-group}.dktv-page .candidates-table.mobile-table tbody tr{border-bottom:1px solid #dee2e6;transition:background-color .2s}.dktv-page .candidates-table.mobile-table tbody tr:hover{background-color:#f8f9fa}.dktv-page .candidates-table.mobile-table tbody td{padding:10px 8px;vertical-align:middle;border-right:1px solid #dee2e6;font-size:13px}.dktv-page .candidates-table.mobile-table tbody td:last-child{border-right:none}.dktv-page .mobile-table th:nth-child(1),.dktv-page .mobile-table td:nth-child(1){width:40px;text-align:center}.dktv-page .mobile-table th:nth-child(2),.dktv-page .mobile-table td:nth-child(2){width:80px;text-align:center}.dktv-page .mobile-table th:nth-child(3),.dktv-page .mobile-table td:nth-child(3){width:120px}.dktv-page .mobile-table th:nth-child(4),.dktv-page .mobile-table td:nth-child(4){width:auto}.dktv-page .mobile-table th:nth-child(5),.dktv-page .mobile-table td:nth-child(5){width:80px;text-align:center}.dktv-page .mobile-info-cell{font-size:12px;line-height:1.3;padding:8px 12px!important}.dktv-page .mobile-info-line{margin-bottom:3px;display:flex;justify-content:space-between;align-items:center}.dktv-page .mobile-info-line:last-child{margin-bottom:0}.dktv-page .info-left{font-weight:500;color:#2c3e50;flex:1}.dktv-page .info-right{font-weight:500;color:#6c757d;text-align:right;flex:1}.dktv-page .phone-cell{padding:8px 12px!important}.dktv-page .phone-container{display:flex;align-items:center;justify-content:center;gap:8px}.dktv-page .phone-number{flex:1;font-weight:500;text-align:center}.dktv-page .edit-phone-btn{padding:4px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background-color .3s}.dktv-page .edit-phone-btn:hover{background:#0056b3}.dktv-page .status-marquee{display:inline-block;animation:marquee-scroll 6s ease-in-out infinite;white-space:nowrap;min-width:100%}.dktv-page .status-container{overflow:hidden;max-width:100%;position:relative;display:inline-block;width:100%;white-space:nowrap}@keyframes marquee-scroll{0%{transform:translate(0)}25%{transform:translate(0)}50%{transform:translate(calc(-100% + 140px))}75%{transform:translate(calc(-100% + 140px))}to{transform:translate(0)}}.dktv-page .status-container:hover .status-marquee{animation-play-state:paused}.desktop-table .status-container{max-width:160px;width:160px;overflow:hidden;position:relative;white-space:nowrap}.desktop-table .status-marquee{animation:marquee-scroll-desktop 6s ease-in-out infinite;white-space:nowrap;display:inline-block;width:-moz-max-content;width:max-content;min-width:100%}@keyframes marquee-scroll-desktop{0%{transform:translate(0)}25%{transform:translate(0)}50%{transform:translate(calc(-100% + 160px))}75%{transform:translate(calc(-100% + 160px))}to{transform:translate(0)}}@keyframes marquee-scroll-mobile-status{0%{transform:translate(0)}25%{transform:translate(0)}50%{transform:translate(calc(-100% + 120px))}75%{transform:translate(calc(-100% + 120px))}to{transform:translate(0)}}.dktv-page .mobile-candidate-cell{padding:8px!important;vertical-align:top;width:100%;max-width:0;overflow:hidden;word-wrap:break-word;white-space:normal}.dktv-page .mobile-row{padding:5px;border-radius:6px;width:100%;max-width:100%;overflow:hidden;word-wrap:break-word;box-sizing:border-box}.dktv-page .mobile-row:last-child{margin-bottom:0}.dktv-page .mobile-row-left{text-align:left}.dktv-page .mobile-row-right{text-align:right}.dktv-page .mobile-row-1{display:flex;justify-content:space-between;align-items:center;gap:10px;width:100%;max-width:100%;overflow:hidden}.mobile-row-1 .mobile-row-left{flex:1;min-width:0;overflow:hidden}.mobile-row-1 .mobile-row-right{flex:0 0 auto;font-weight:500;color:#495057}.dktv-page .mobile-row-2{display:flex;gap:5px;align-items:flex-start;width:100%;max-width:100%;overflow:hidden}.mobile-row-2 .mobile-row-left{flex:1;min-width:0;overflow:hidden;word-wrap:break-word}.mobile-row-2 .mobile-row-right{flex:0 0 90px;min-width:90px;max-width:90px;display:flex;justify-content:flex-end;align-items:flex-start}.dktv-page .mobile-info-column{padding:2px}.dktv-page .mobile-info-item{margin-bottom:6px;font-size:13px;line-height:1.4;word-wrap:break-word;overflow-wrap:break-word;white-space:normal;max-width:100%}.dktv-page .mobile-info-item:last-child{margin-bottom:0}.dktv-page .mobile-info-item strong{color:#2c3e50;margin-right:5px}.dktv-page .mobile-avatar-info-row{display:flex;gap:12px;align-items:flex-start;width:100%;max-width:100%;overflow:hidden}.dktv-page .mobile-avatar-container{flex-shrink:0;width:40px;height:60px}.dktv-page .mobile-candidate-avatar{width:100%;height:100%;-o-object-fit:cover;object-fit:cover;border-radius:8px;border:2px solid #e9ecef}.dktv-page .mobile-no-avatar{width:100%;height:100%;background:#f8f9fa;border:2px solid #e9ecef;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:9px;color:#6c757d;text-align:center;line-height:1.1}.dktv-page .mobile-basic-info{flex:1;display:flex;flex-direction:column;justify-content:center;min-height:60px;min-width:0;overflow:hidden;word-wrap:break-word}.dktv-page .mobile-status-left{display:flex;justify-content:flex-start;align-items:center;gap:8px;flex:1;min-width:0;width:100%}.dktv-page .mobile-status-left strong{color:#2c3e50;font-size:12px}.mobile-status-left .status-container{flex:1;width:auto;max-width:none!important;display:flex;justify-content:flex-start}.mobile-status-left .status-badge{font-size:11px;padding:4px 8px;width:auto;max-width:-moz-fit-content;max-width:fit-content;text-align:left}.mobile-status-left .status-marquee{animation:marquee-scroll-mobile-status 6s ease-in-out infinite}.dktv-page .mobile-delete-right{display:flex;justify-content:flex-end;align-items:center;flex-shrink:0;width:auto}.dktv-page .mobile-delete-btn{width:28px;height:28px;border-radius:50%;border:2px solid #dc3545;background:#dc3545;color:#fff;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;padding:0;line-height:1}.dktv-page .mobile-delete-btn:hover:not(:disabled){background:#c82333;border-color:#c82333;transform:scale(1.1)}.mobile-delete-btn.disabled{background:#6c757d;border-color:#6c757d;cursor:not-allowed;opacity:.6}.dktv-page .mobile-nha-thoi-vu{background:#27beec;border:1px solid #5a6fd8;border-radius:8px;padding:4px;margin-bottom:0;display:flex;flex-direction:column;align-items:flex-end;gap:2px;box-shadow:0 2px 6px #5a6fd84d;position:relative;overflow:hidden;text-align:right;width:auto;max-width:75px}.dktv-page .mobile-nha-thoi-vu:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.2),transparent);animation:shimmer 2s infinite}@keyframes shimmer{0%{left:-100%}to{left:100%}}.mobile-nha-thoi-vu .nha-thoi-vu-label{font-size:8px;font-weight:600;color:#fff;text-transform:uppercase;letter-spacing:.5px;margin-bottom:2px;text-shadow:0 1px 2px rgba(0,0,0,.2);text-align:right;width:100%}.mobile-nha-thoi-vu .nha-thoi-vu-value{font-size:9px;font-weight:500;color:#fff;text-align:right;line-height:1.2;text-shadow:0 1px 2px rgba(0,0,0,.2);word-break:break-word;-webkit-hyphens:auto;hyphens:auto;width:100%}.dktv-page .mobile-nha-thoi-vu-row{display:flex;justify-content:flex-end;align-items:center;width:100%;margin-bottom:8px}.dktv-page .mobile-action-buttons-row{display:flex;justify-content:center;align-items:center;width:100%}.dktv-page .mobile-row-3{display:flex;justify-content:flex-end;align-items:center}.mobile-row-3 .mobile-row-right{font-size:11px;color:#6c757d;font-style:italic}@media (max-width: 1024px) and (min-width: 769px){.dktv-page .desktop-table th,.dktv-page .desktop-table td{padding:7px 5px;font-size:13px}.dktv-page .candidates-table.desktop-table tbody{max-height:calc(100vh - 300px)}.dktv-page .candidates-table.desktop-table thead th:nth-child(3),.dktv-page .candidates-table.desktop-table tbody td:nth-child(3){flex:0 0 16%;min-width:130px}.dktv-page .candidates-table.desktop-table thead th:nth-child(7),.dktv-page .candidates-table.desktop-table tbody td:nth-child(7){flex:0 0 11%;min-width:95px}.dktv-page .candidates-table.desktop-table thead th:nth-child(9),.dktv-page .candidates-table.desktop-table tbody td:nth-child(9){flex:0 0 14%;min-width:130px}}@media (max-width: 768px){.dktv-page .candidates-table.desktop-table{display:none!important}.dktv-page .candidates-table.mobile-table{display:table!important;width:100%;table-layout:fixed}.dktv-page .candidates-table-container{overflow-x:hidden;overflow-y:auto!important;width:100%;max-width:100vw;max-height:calc(100vh - 200px)!important;flex:1!important}.dktv-page .mobile-table{display:table!important;width:100%!important;table-layout:auto!important}.dktv-page .mobile-table tbody{display:table-row-group!important}.dktv-page .mobile-table tr{display:table-row!important;border-bottom:1px solid #ddd!important}.dktv-page .mobile-table .mobile-candidate-cell{display:table-cell!important;width:100%!important;padding:12px!important;vertical-align:top!important}.dktv-page .mobile-info-cell{font-size:13px!important;line-height:1.4!important;padding:12px 15px!important}.dktv-page .mobile-info-line{margin-bottom:8px!important;display:block!important;word-wrap:break-word!important}.dktv-page .mobile-info-line:last-child{margin-bottom:0!important}.dktv-page .mobile-line-1{display:flex!important;justify-content:space-between!important;align-items:flex-start!important;flex-wrap:wrap!important;border-bottom:1px solid #e9ecef!important;padding-bottom:6px!important;margin-bottom:10px!important}.mobile-line-1 .info-left{flex:1!important;text-align:left!important;color:#2c3e50!important;font-size:13px!important}.mobile-line-1 .info-right{flex:0 0 auto!important;text-align:right!important;color:#2c3e50!important;font-size:13px!important}.mobile-line-1 .status-badge{font-size:11px!important;padding:3px 8px!important;margin-left:5px!important}.dktv-page .mobile-line-2,.dktv-page .mobile-line-3,.dktv-page .mobile-line-4,.dktv-page .mobile-line-5,.dktv-page .mobile-line-6{text-align:left!important}.mobile-line-2 .info-left,.mobile-line-3 .info-left,.mobile-line-4 .info-left,.mobile-line-5 .info-left,.mobile-line-6 .info-left{color:#2c3e50!important;font-size:13px!important;display:block!important}.dktv-page .mobile-line-7{text-align:right!important;border-top:1px solid #e9ecef!important;padding-top:6px!important;margin-top:8px!important}.mobile-line-7 .info-right{color:#6c757d!important;font-style:italic!important;font-size:12px!important}.dktv-page .mobile-action-buttons{display:flex!important;flex-direction:column!important;gap:20px!important;align-items:center!important;vertical-align:middle!important}.mobile-action-buttons .action-btn{width:100%!important;max-width:120px!important;padding:12px!important;font-size:11px!important;display:flex!important;align-items:center!important;justify-content:center!important;gap:4px;border-radius:4px!important;transition:all .2s ease!important}.mobile-action-buttons .action-btn svg{width:12px!important;height:24px!important;flex-shrink:0!important}.mobile-action-buttons .action-btn span{font-size:10px!important;font-weight:500!important}.dktv-page .attendance-btn{background:#17a2b8!important;color:#fff!important}.dktv-page .attendance-btn:hover{background:#138496!important}.dktv-page .attendance-btn:disabled{background:#6c757d!important;cursor:not-allowed!important;opacity:.7}.dktv-page .attendance-status-present{display:flex!important;align-items:center!important;gap:4px!important;padding:8px!important;background:#caeeda!important;color:#330303!important;border-radius:6px!important;font-size:12px!important;font-weight:500!important;border:none!important;cursor:default!important;max-width:180px!important;white-space:nowrap!important;overflow:hidden!important;text-overflow:ellipsis!important}.dktv-page .attendance-status-present svg{width:12px!important;height:12px!important;flex-shrink:0!important}.dktv-page .edit-btn{background:#007bff!important;color:#fff!important}.dktv-page .edit-btn:hover{background:#0056b3!important}.dktv-page .delete-btn{background:#dc3545!important;color:#fff!important}.dktv-page .delete-btn:hover{background:#c82333!important}.dktv-page .mobile-info-line strong{font-weight:600!important;color:#495057!important}.dktv-page .status-container{max-width:150px}.dktv-page .status-marquee{animation:marquee-pingpong-mobile 10s ease-in-out infinite}}@keyframes marquee-pingpong-mobile{45%{transform:translate(calc(-100% + 150px))}55%{transform:translate(calc(-100% + 150px))}}@media (max-width: 480px){.dktv-page .mobile-table th,.dktv-page .mobile-table td{padding:8px 6px;font-size:12px}.dktv-page .mobile-info-cell{font-size:11px;padding:6px 8px!important}.dktv-page .mobile-info-line{margin-bottom:4px}.dktv-page .mobile-info-line:first-child{border-bottom:1px solid #eee;padding-bottom:3px;margin-bottom:6px}.dktv-page .info-left,.dktv-page .info-right{font-size:11px}}.dktv-page .attendance-status-present{text-align:center;padding:3px 6px}.dktv-page .attendance-status-text{font-size:14px;font-weight:600;color:#28a745;margin-bottom:1px}.dktv-page .attendance-time-text{font-size:12px;color:#666;line-height:1.1}.dktv-page .attendance-btn{padding:4px 8px!important;font-size:11px!important;white-space:nowrap;min-width:70px;background:#007bff;color:#fff;border:none;border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:3px;transition:background-color .2s}.dktv-page .attendance-btn:hover:not(:disabled){background:#0056b3}.dktv-page .attendance-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.7}.dktv-page .attendance-btn span{font-size:11px}@media (max-width: 1200px){.dktv-page .attendance-btn{padding:4px 8px!important;font-size:11px!important;min-width:70px}.dktv-page .attendance-btn span,.dktv-page .attendance-status-text{font-size:11px}.dktv-page .attendance-time-text{font-size:9px}}@media (max-width: 992px){.dktv-page .attendance-btn{padding:3px 6px!important;font-size:10px!important;min-width:60px}.dktv-page .attendance-btn span{font-size:10px}}.dktv-page .candidate-name-with-avatar{padding:6px 4px!important;justify-content:flex-start!important;text-align:left!important}.dktv-page .name-avatar-container{display:flex;align-items:center;gap:20px;justify-content:flex-start;width:100%}.dktv-page .avatar-container-inline{flex-shrink:0}.dktv-page .candidate-avatar-inline{width:32px;height:48px;-o-object-fit:cover;object-fit:cover;border-radius:4px;border:1px solid #ddd;box-shadow:0 1px 3px #0000001a}.dktv-page .no-avatar-inline{width:32px;height:48px;background:#f8f9fa;border:1px solid #ddd;border-radius:4px;display:flex;align-items:center;justify-content:center;font-size:9px;color:#666;text-align:center;line-height:1.1}.dktv-page .candidate-name-text{flex:1;font-weight:500;color:#333;line-height:1.2;word-break:break-word;text-align:left;font-size:16px}@media (max-width: 1200px){.dktv-page .name-avatar-container{gap:8px;justify-content:flex-start}.dktv-page .candidate-avatar-inline{width:32px;height:48px}.dktv-page .no-avatar-inline{width:32px;height:48px;font-size:9px}.dktv-page .candidate-name-text{font-size:13px;text-align:left}}@media (max-width: 992px){.dktv-page .name-avatar-container{gap:6px;justify-content:flex-start}.dktv-page .candidate-avatar-inline{width:28px;height:42px}.dktv-page .no-avatar-inline{width:28px;height:42px;font-size:8px}.dktv-page .candidate-name-text{font-size:12px;text-align:left}}.filter-menu{position:absolute;top:100%;left:0;background:white;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:1000;width:300px;max-height:400px;display:none;flex-direction:column;font-size:14px}.filter-menu.show{display:flex}.filter-search{padding:8px;border-bottom:1px solid #eee}.filter-search .col-filter{width:100%;padding:6px 8px;border:1px solid #ddd;border-radius:3px;font-size:13px}.filter-controls{padding:10px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;background:#f8f9fa;font-size:12px}.select-all-btn{background:none;border:none;color:#007bff;cursor:pointer;font-size:12px;padding:4px 8px;border-radius:3px;font-weight:500;transition:background-color .15s ease}.select-all-btn:hover{background:rgba(0,123,255,.1);text-decoration:none}.selected-count{font-size:12px;color:#666;font-weight:500;padding:3px 8px;border-radius:12px}.filter-values,.filter-options{flex:1;overflow-y:auto;max-height:250px;padding:4px 0}.filter-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;margin:0;font-size:13px;border-bottom:1px solid #f0f0f0;transition:background-color .15s ease}.filter-option:hover{background:#f8f9fa}.filter-option:last-child{border-bottom:none}.filter-option input[type=checkbox]{margin-right:10px;margin-left:0;width:16px;height:16px;cursor:pointer;accent-color:#007bff}.filter-option-text{flex:1;line-height:1.4;word-break:break-word;cursor:pointer;margin-right:8px;text-align:left;overflow:hidden;text-overflow:ellipsis}.filter-option-count{flex:0 0 auto!important;font-size:11px!important;color:#666!important;background-color:#e9ecef!important;padding:4px 8px!important;border-radius:10px!important;font-weight:500!important;text-align:center!important;min-width:28px!important;max-width:60px!important;white-space:nowrap!important;display:flex!important;align-items:center!important;justify-content:center!important}.filter-value-item{display:flex;align-items:center;padding:8px 12px;cursor:pointer;margin:0;font-size:13px;border-bottom:1px solid #f0f0f0;transition:background-color .15s ease}.filter-value-item:hover{background:#f8f9fa}.filter-value-item:last-child{border-bottom:none}.filter-value-item input[type=checkbox]{margin-right:10px;margin-left:0;width:16px;height:16px;cursor:pointer;accent-color:#007bff}.filter-value-text{flex:1;line-height:1.4;word-break:break-word;cursor:pointer;margin-right:8px;text-align:left;overflow:hidden;text-overflow:ellipsis}.filter-value-count{flex:0 0 auto!important;font-size:11px!important;color:#666!important;background-color:#e9ecef!important;padding:4px 8px!important;border-radius:10px!important;font-weight:500!important;text-align:center!important;min-width:28px!important;max-width:60px!important;white-space:nowrap!important;display:flex!important;align-items:center!important;justify-content:center!important}.filter-value-item input[type=checkbox]:checked{background-color:#007bff;border-color:#007bff}.no-values{padding:12px;text-align:center;color:#999;font-style:italic;font-size:13px}.filter-actions{padding:8px;border-top:1px solid #eee;display:flex;gap:8px;background:#f9f9f9}.filter-actions button{flex:1;padding:6px 12px;border:1px solid #ddd;border-radius:3px;background:white;cursor:pointer;font-size:12px}.filter-actions button:hover{background:#f5f5f5}.filter-actions button:first-child{background:#007bff;color:#fff;border-color:#007bff;font-weight:500}.filter-actions button:first-child:hover{background:#0056b3;border-color:#0056b3}.filter-actions button:last-child{background:#6c757d;color:#fff;border-color:#6c757d}.filter-actions button:last-child:hover{background:#545b62;border-color:#545b62}.filter-values::-webkit-scrollbar{width:8px}.filter-values::-webkit-scrollbar-track{background:#f8f9fa;border-radius:4px}.filter-values::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px;border:1px solid #f8f9fa}.filter-values::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.filter-values{scrollbar-width:thin;scrollbar-color:#c1c1c1 #f8f9fa}.dktv-page .filter-menu{position:absolute;top:100%;left:0;background:white;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 12px #00000026;z-index:1000;width:300px;max-height:400px;display:none;flex-direction:column;font-size:14px}.dktv-page .filter-menu.show{display:flex}.dktv-page .filter-values{flex:1;overflow-y:auto;max-height:250px;padding:4px 0}.dktv-page .filter-values::-webkit-scrollbar{width:8px}.dktv-page .filter-values::-webkit-scrollbar-track{background:#f8f9fa;border-radius:4px}.dktv-page .filter-values::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:4px;border:1px solid #f8f9fa}.dktv-page .filter-values::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.dktv-page .filter-values{scrollbar-width:thin;scrollbar-color:#c1c1c1 #f8f9fa}.dktv-page .th-cell{position:relative;padding:12px 8px;background:#6c757d;align-items:center;justify-content:center;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none}.dktv-page .th-cell:hover{background:#6c757d}.dktv-page .th-cell span{display:flex;align-items:center;justify-content:space-between;gap:4px;font-weight:600;color:#fff;width:100%;position:relative;min-height:24px}.dktv-page .th-cell .header-text{flex:1;text-align:center;display:flex;align-items:center;justify-content:center;font-weight:600;color:#fff}.dktv-page .filter-menu span,.dktv-page .filter-value-text,.dktv-page .filter-option-text{color:#333!important}.dktv-page .filter-menu,.dktv-page .filter-menu *{color:inherit}.dktv-page .filter-menu input::-moz-placeholder{color:#333!important}.dktv-page .filter-menu .filter-value-text,.dktv-page .filter-menu .filter-option-text,.dktv-page .filter-menu input::placeholder,.dktv-page .filter-menu .no-values{color:#333!important}.dktv-page .filter-btn{background:none;border:none;color:#fffc;cursor:pointer;padding:2px;margin-left:auto;border-radius:3px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.dktv-page .filter-btn:hover{background:rgba(255,255,255,.2);color:#fff}.dktv-page .filter-btn:focus{outline:none;background:rgba(255,255,255,.3);color:#fff}.dktv-page .th-cell:first-child .filter-menu{left:0;transform:none}.dktv-page .th-cell:last-child .filter-menu,.dktv-page .th-cell:nth-last-child(-n+2) .filter-menu{left:auto;right:0;transform:none}.dktv-page .th-cell:not(:first-child):not(:last-child):not(:nth-last-child(2)) .filter-menu{left:50%;transform:translate(-50%)}.dktv-page .filter-menu{max-width:90vw;min-width:250px}@media (max-width: 768px){.dktv-page .filter-menu{width:280px;left:50%!important;right:auto!important;transform:translate(-50%)!important}}.dktv-page .filter-controls{padding:10px 12px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #eee;background:#f8f9fa;font-size:12px}.dktv-page .select-all-btn{background:none;border:none;color:#007bff!important;cursor:pointer;font-size:12px;padding:4px 8px;border-radius:3px;font-weight:500;transition:background-color .15s ease}.dktv-page .select-all-btn:hover{background:rgba(0,123,255,.1);text-decoration:none}.dktv-page .selected-count{font-size:12px;color:#666!important;font-weight:500;background:#e9ecef;padding:3px 8px;border-radius:12px}.dktv-page .filter-search{padding:8px;border-bottom:1px solid #eee}.dktv-page .filter-search .col-filter{width:100%;padding:6px 8px;border:1px solid #ddd;border-radius:3px;font-size:13px}.dktv-page .menu-actions{padding:8px;border-top:1px solid #eee;display:flex;gap:8px;background:#f9f9f9}.dktv-page .menu-actions button{flex:1;padding:6px 12px;border:1px solid #ddd;border-radius:3px;background:white;cursor:pointer;font-size:12px}.dktv-page .menu-actions button:hover{background:#f5f5f5}.dktv-page .menu-actions button:first-child{background:#007bff;color:#fff;border-color:#007bff;font-weight:500}.dktv-page .menu-actions button:first-child:hover{background:#0056b3;border-color:#0056b3}.dktv-page .menu-actions button:last-child{background:#6c757d;color:#fff;border-color:#6c757d}.dktv-page .menu-actions button:last-child:hover{background:#545b62;border-color:#545b62}.dktv-page .no-values{padding:12px;text-align:center;color:#999;font-style:italic;font-size:13px}.dktv-page .filter-option{display:flex;align-items:center;padding:8px 12px;cursor:pointer;margin:0;font-size:13px;border-bottom:1px solid #f0f0f0;transition:background-color .15s ease}.dktv-page .filter-option:hover{background:#f8f9fa}.dktv-page .filter-option:last-child{border-bottom:none}.dktv-page .filter-option input[type=checkbox]{margin-right:10px;margin-left:0;width:16px;height:16px;cursor:pointer;accent-color:#007bff}.dktv-page .filter-option-text{flex:1;line-height:1.4;word-break:break-word;cursor:pointer;margin-right:8px;text-align:left;overflow:hidden;text-overflow:ellipsis}.dktv-page .filter-option-count{flex:0 0 auto!important;font-size:11px!important;color:#666!important;background-color:#e9ecef!important;padding:4px 8px!important;border-radius:10px!important;font-weight:500!important;text-align:center!important;min-width:28px!important;max-width:60px!important;white-space:nowrap!important;display:flex!important;align-items:center!important;justify-content:center!important}.dktv-page .select-all-option{background:#f8f9fa;border-bottom:2px solid #ddd;font-weight:500}.dktv-page .select-all-option:hover{background:#e9ecef}.dktv-page .filter-value-item{display:flex;align-items:center;padding:8px 12px;cursor:pointer;margin:0;font-size:13px;border-bottom:1px solid #f0f0f0;transition:background-color .15s ease}.dktv-page .filter-value-item:hover{background:#f8f9fa}.dktv-page .filter-value-item:last-child{border-bottom:none}.dktv-page .filter-value-item input[type=checkbox]{margin-right:10px;margin-left:0;width:16px;height:16px;cursor:pointer;accent-color:#007bff}.dktv-page .filter-value-text{flex:1;line-height:1.4;word-break:break-word;cursor:pointer;margin-right:8px;text-align:left;overflow:hidden;text-overflow:ellipsis}.dktv-page .filter-value-count{flex:0 0 auto!important;font-size:11px!important;color:#666!important;background-color:#e9ecef!important;padding:4px 8px!important;border-radius:10px!important;font-weight:500!important;text-align:center!important;min-width:28px!important;max-width:60px!important;white-space:nowrap!important;display:flex!important;align-items:center!important;justify-content:center!important}.dktv-page .modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.dktv-page .modal-content{background:white;border-radius:12px;max-width:800px;width:95%;max-height:95vh;box-shadow:0 12px 48px #0003;display:flex;flex-direction:column;overflow:hidden}.dktv-page .add-candidate-modal{display:flex;flex-direction:column;height:90vh;max-height:90vh}.dktv-page .modal-header-fixed{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef;background:white;flex-shrink:0;position:relative;z-index:10}.dktv-page .modal-header-fixed h3{margin:0;font-size:20px;font-weight:600;color:#2c3e50}.dktv-page .modal-close-btn{background:none;border:none;font-size:24px;color:#6c757d;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.dktv-page .modal-close-btn:hover{background:#f8f9fa;color:#343a40}.dktv-page .modal-container-scrollable{flex:1;overflow-y:auto;overflow-x:hidden;padding:24px;background:white}.dktv-page .modal-container-scrollable::-webkit-scrollbar{width:6px}.dktv-page .modal-container-scrollable::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.dktv-page .modal-container-scrollable::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.dktv-page .modal-container-scrollable::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.dktv-page .modal-footer-fixed{display:flex;justify-content:flex-end;gap:12px;padding:16px 24px;border-top:1px solid #e9ecef;background:#f8f9fa;flex-shrink:0}.dktv-page .candidate-info-modal-new{max-width:700px;max-height:100vh;width:95%;display:flex;flex-direction:column;overflow:hidden}.dktv-page .info-frame-1{margin-bottom:10px;padding:25px;background:linear-gradient(135deg,#f8fbff 0%,#e8f4fd 100%);border-radius:12px;border:2px solid #e3f2fd;box-shadow:0 2px 8px #007bff1a}.dktv-page .desktop-layout{display:grid;grid-template-columns:140px 1fr;gap:20px}.dktv-page .mobile-layout{display:none}.dktv-page .avatar-col{display:flex;justify-content:center;align-items:center}.dktv-page .basic-info-col{display:flex;flex-direction:column;gap:10px}.dktv-page .info-line{display:flex;justify-content:space-between;align-items:flex-start;min-height:32px;flex-wrap:wrap;gap:10px;max-width:100%;overflow:hidden}.dktv-page .name-text{font-size:22px;font-weight:600;color:#2c3e50;flex:1;max-width:60%;word-wrap:break-word;overflow-wrap:break-word}.dktv-page .nha-thoi-vu-select{padding:6px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:white;min-width:200px}.dktv-page .nha-thoi-vu-select:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.dktv-page .nha-thoi-vu-display{display:flex;align-items:center;gap:8px;background:#f8f9fa;padding:8px 12px;border-radius:6px;border:1px solid #e9ecef;transition:all .2s ease}.dktv-page .nha-thoi-vu-display:hover{background:#e9ecef;border-color:#007bff}.dktv-page .nha-thoi-vu-text{font-size:13px;color:#495057;font-weight:500;margin:0}.dktv-page .edit-nha-thoi-vu-btn{background:#007bff;color:#fff;border:none;border-radius:4px;width:24px;height:24px;min-width:24px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #007bff33}.dktv-page .edit-nha-thoi-vu-btn:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 2px 8px #007bff4d}.dktv-page .edit-nha-thoi-vu-btn:active{transform:translateY(0);box-shadow:0 1px 3px #007bff33}.dktv-page .mobile-row-1{display:flex;justify-content:space-between;align-items:center}.mobile-row-1 .left-side{display:flex;align-items:center;flex:0 0 auto}.mobile-row-1 .right-side{display:flex;align-items:center;flex:1;justify-content:flex-end}.dktv-page .mobile-row-2{display:flex;justify-content:center;align-items:center;padding:10px 0}.dktv-page .mobile-row-3{display:flex;justify-content:center;align-items:center}.dktv-page .mobile-row-4{display:flex;justify-content:center;align-items:center;padding:8px 0}.dktv-page .mobile-row-5{display:flex;justify-content:flex-end;align-items:center}.mobile-row-1 .contract-badge{margin:0;font-size:12px;padding:4px 8px}.mobile-row-1 .nha-thoi-vu-display{display:flex;align-items:center;gap:6px;background:#f8f9fa;padding:6px 10px;border-radius:6px;border:1px solid #e9ecef;max-width:200px;transition:all .2s ease}.mobile-row-1 .nha-thoi-vu-display:hover{background:#e9ecef;border-color:#007bff}.mobile-row-1 .nha-thoi-vu-text{font-size:12px;color:#495057;font-weight:500;margin:0}.mobile-row-1 .edit-nha-thoi-vu-btn{background:#007bff;color:#fff;border:none;border-radius:4px;width:20px;height:20px;min-width:20px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;box-shadow:0 1px 3px #007bff33}.mobile-row-1 .edit-nha-thoi-vu-btn:hover{background:#0056b3;transform:translateY(-1px);box-shadow:0 2px 6px #007bff4d}.mobile-row-1 .edit-nha-thoi-vu-btn:active{transform:translateY(0);box-shadow:0 1px 3px #007bff33}.mobile-row-3 .name-text{font-size:25px;font-weight:600;color:#2c3e50;text-align:center}.mobile-row-4 .status-badge{font-size:12px;padding:4px 8px;min-width:auto;width:auto;max-width:-moz-fit-content;max-width:fit-content;text-align:left}.mobile-row-5 .register-time{font-size:11px;color:#6c757d;font-style:italic}.dktv-page .info-frame-2{margin-bottom:20px}.dktv-page .detail-row{display:flex;gap:20px;margin-bottom:15px;flex-wrap:wrap}.dktv-page .detail-group{flex:1;min-width:200px;display:flex;flex-direction:column;gap:5px}.detail-group.full-width{flex:100%;min-width:100%}.dktv-page .info-line .status-container{max-width:300px;width:300px;overflow:hidden;position:relative}.dktv-page .info-line .status-marquee{animation:marquee-pingpong-modal 8s ease-in-out infinite;white-space:nowrap;display:inline-block;width:-moz-max-content;width:max-content}.dktv-page .basic-info-col .status-container{max-width:400px;width:400px;overflow:hidden;position:relative}.dktv-page .basic-info-col .status-marquee{animation:marquee-pingpong-modal-full 8s ease-in-out infinite;white-space:nowrap;display:inline-block;width:-moz-max-content;width:max-content}@keyframes marquee-pingpong-modal{0%{transform:translate(0)}20%{transform:translate(0)}50%{transform:translate(calc(300px - 100%))}80%{transform:translate(calc(300px - 100%))}to{transform:translate(0)}}@keyframes marquee-pingpong-modal-full{0%{transform:translate(0)}20%{transform:translate(0)}50%{transform:translate(calc(400px - 100%))}80%{transform:translate(calc(400px - 100%))}to{transform:translate(0)}}.dktv-page .info-line .status-container:hover .status-marquee,.dktv-page .basic-info-col .status-container:hover .status-marquee{animation-play-state:paused}.dktv-page .detail-group label{font-weight:600;color:#495057;font-size:14px}.dktv-page .detail-group span{color:#2c3e50;font-size:15px;padding:8px 12px;background:#f8f9fa;border-radius:4px;border:1px solid #e9ecef}.dktv-page .edit-input{padding:8px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;transition:border-color .3s}.dktv-page .edit-input:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.dktv-page .cccd-images{margin-top:20px;padding-top:20px;border-top:1px solid #eee}.dktv-page .cccd-images h5{margin:0 0 15px;font-size:16px;font-weight:600;color:#2c3e50}.dktv-page .avatar-container,.dktv-page .cccd-image-container{position:relative;display:inline-block}.dktv-page .edit-image-btn{position:absolute;top:8px;right:8px;background:rgba(0,0,0,.7);color:#fff;border:none;border-radius:50%;width:32px;height:32px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;z-index:10}.dktv-page .edit-image-btn:hover{background:rgba(0,0,0,.9);transform:scale(1.1)}.dktv-page .hidden-file-input{display:none!important}.dktv-page .no-cccd-image{width:165px;height:120px;background:#f8f9fa;border:2px dashed #dee2e6;border-radius:8px;display:flex;align-items:center;justify-content:center;color:#6c757d;font-style:italic;text-align:center;padding:10px;box-sizing:border-box}.dktv-page .no-cccd-image span{font-size:12px;line-height:1.4}.dktv-page .cccd-image-item img{max-width:200px;max-height:120px;-o-object-fit:cover;object-fit:cover;border-radius:6px;cursor:pointer;transition:transform .2s ease}.dktv-page .info-frame-cccd{margin-bottom:20px;padding:20px;background:white;border-radius:8px;border:1px solid #e9ecef}.dktv-page .cccd-images-row:not(.mobile-cccd-row){display:flex;gap:20px;justify-content:center}.dktv-page .cccd-images-row:not(.mobile-cccd-row) .cccd-image-item{text-align:center}.dktv-page .cccd-image-item img:hover{transform:scale(1.02)}.avatar-col .avatar-container,.mobile-row-2 .avatar-container{position:relative;display:inline-block}.dktv-page .mobile-cccd-row{display:flex!important;flex-direction:row!important;gap:10px!important;flex-wrap:nowrap!important;width:100%!important;max-width:100%!important;box-sizing:border-box!important}.mobile-cccd-row .cccd-image-item{flex:1!important;min-width:0!important;text-align:center!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important}.mobile-cccd-row .cccd-image-item label{display:block!important;text-align:center!important;margin-bottom:8px!important;font-weight:600!important;color:#495057!important;font-size:14px!important;width:100%!important}.mobile-cccd-row .cccd-image-container{flex:0 0 auto!important;max-width:none!important;display:flex!important;justify-content:center!important;align-items:center!important;position:relative!important;box-sizing:border-box!important;min-height:120px!important;width:100%!important}.dktv-page .mobile-cccd-row .cccd-image-item img,.dktv-page .mobile-cccd-row .cccd-image-container img{max-width:200px!important;max-height:200px!important;width:auto!important;height:auto!important;-o-object-fit:contain!important;object-fit:contain!important;border-radius:6px!important}.dktv-page .notification-modal-overlay{background:rgba(0,0,0,.7);animation:fadeIn .2s ease}.dktv-page .notification-modal{max-width:400px;width:90%;max-height:none;border-radius:12px;overflow:hidden;animation:slideInDown .3s ease}.dktv-page .notification-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;background:white;border-bottom:1px solid #e9ecef}.dktv-page .notification-title-section{display:flex;align-items:center;gap:16px;flex:1}.dktv-page .notification-title{margin:0;font-size:18px;font-weight:600;color:#2c3e50}.dktv-page .notification-icon{width:48px;height:48px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:24px;font-weight:700;color:#fff;flex-shrink:0}.notification-icon.success{background:linear-gradient(135deg,#28a745,#20c997)}.notification-icon.error{background:linear-gradient(135deg,#dc3545,#e83e8c)}.notification-icon.info{background:linear-gradient(135deg,#007bff,#6f42c1)}.dktv-page .notification-body{padding:20px 24px;background:white;text-align:center}.dktv-page .notification-body p{margin:0;font-size:16px;color:#2c3e50;line-height:1.5}.dktv-page .notification-footer{padding:16px 24px 20px;background:white;text-align:center}.dktv-page .notification-ok-btn{background:#007bff;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s;min-width:80px}.dktv-page .notification-ok-btn:hover{background:#0056b3}.dktv-page .confirm-modal-overlay{background:rgba(0,0,0,.7);animation:fadeIn .2s ease}.dktv-page .confirm-modal{max-width:400px;width:90%;max-height:none;border-radius:12px;overflow:hidden;animation:slideInDown .3s ease}.dktv-page .confirm-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px 16px;background:white;border-bottom:1px solid #e9ecef}.dktv-page .confirm-icon{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,#ffc107,#fd7e14);display:flex;align-items:center;justify-content:center;font-size:24px;color:#fff}.dktv-page .confirm-body{padding:20px 24px;background:white;text-align:center}.dktv-page .confirm-body p{margin:0;font-size:16px;color:#2c3e50;line-height:1.5}.dktv-page .confirm-footer{padding:16px 24px 20px;background:white;display:flex;gap:12px;justify-content:center}.dktv-page .confirm-yes-btn{background:#dc3545;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s;min-width:80px}.dktv-page .confirm-yes-btn:hover{background:#c82333}.dktv-page .confirm-no-btn{background:#6c757d;color:#fff;border:none;padding:10px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s;min-width:80px}.dktv-page .confirm-no-btn:hover{background:#5a6268}@media (min-width: 769px){.dktv-page .basic-info-col{min-width:0;overflow:hidden}.dktv-page .info-line{min-width:0}.dktv-page .info-line .nha-thoi-vu-display{max-width:300px;min-width:150px}}@media (max-width: 1024px) and (min-width: 769px){.dktv-page .info-line{flex-direction:column;align-items:flex-start;gap:8px}.dktv-page .info-line .nha-thoi-vu-display,.dktv-page .info-line .status-container,.dktv-page .info-line .register-time{max-width:100%;width:100%}}@media (max-width: 768px){.dktv-page .desktop-layout{display:none}.dktv-page .mobile-layout{display:block}.mobile-row-3.text-center,.mobile-row-4.text-center{display:flex;justify-content:center;align-items:center}.dktv-page .mobile-cccd-row{gap:8px!important}.dktv-page .edit-image-btn{width:28px;height:28px;top:6px;right:6px}.mobile-cccd-row .cccd-image-container{max-width:none!important;min-height:100px!important;width:100%!important}.dktv-page .mobile-cccd-row .cccd-image-item img,.dktv-page .mobile-cccd-row .cccd-image-container img{max-width:100px!important;max-height:100px!important;width:auto!important;height:auto!important;-o-object-fit:contain!important;object-fit:contain!important;border-radius:6px!important}}@media (max-width: 480px){.dktv-page .notification-modal,.dktv-page .confirm-modal{width:95%;margin:20px}.dktv-page .notification-header,.dktv-page .confirm-header{padding:16px 20px 12px}.dktv-page .notification-title-section{gap:12px}.dktv-page .notification-title{font-size:16px}.dktv-page .notification-body,.dktv-page .confirm-body{padding:16px 20px}.dktv-page .notification-footer,.dktv-page .confirm-footer{padding:12px 20px 16px}.dktv-page .notification-icon,.dktv-page .confirm-icon{width:40px;height:40px;font-size:20px}.dktv-page .confirm-footer{flex-direction:column}.dktv-page .confirm-yes-btn,.dktv-page .confirm-no-btn,.dktv-page .notification-ok-btn{width:100%}.dktv-page .edit-image-btn{width:24px;height:24px;top:4px;right:4px}.mobile-cccd-row .cccd-image-container{max-width:none!important;min-height:80px!important;width:100%!important}.dktv-page .mobile-cccd-row .cccd-image-item img,.dktv-page .mobile-cccd-row .cccd-image-container img{max-width:120px!important;max-height:120px!important;width:auto!important;height:auto!important;-o-object-fit:contain!important;object-fit:contain!important;border-radius:6px!important}.dktv-page .mobile-cccd-row{gap:5px!important}}.dktv-page .fullscreen-image-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:99999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);animation:fadeIn .3s ease}.dktv-page .fullscreen-image-container{position:relative;max-width:95vw;max-height:95vh;display:flex;align-items:center;justify-content:center}.dktv-page .fullscreen-close-btn{position:absolute;top:-50px;right:-10px;background:rgba(255,255,255,.9);color:#333;border:none;font-size:32px;width:44px;height:44px;border-radius:50%;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;z-index:100000}.dktv-page .fullscreen-close-btn:hover{background:white;transform:scale(1.1)}.dktv-page .fullscreen-image{max-width:100%;max-height:100%;-o-object-fit:contain;object-fit:contain;border-radius:8px;box-shadow:0 8px 32px #0000004d}@keyframes slideInDown{0%{opacity:0;transform:translateY(-50px) scale(.9)}to{opacity:1;transform:translateY(0) scale(1)}}.dktv-page .nha-thoi-vu-modal{max-width:600px;width:90%;max-height:80vh;border-radius:12px;overflow:hidden;animation:slideInDown .3s ease}.dktv-page .nha-thoi-vu-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid #e9ecef;background:white}.dktv-page .nha-thoi-vu-modal .modal-header h3{margin:0;font-size:20px;font-weight:600;color:#2c3e50}.dktv-page .nha-thoi-vu-list{max-height:60vh;overflow-y:auto;padding:0;margin:0}.dktv-page .nha-thoi-vu-list::-webkit-scrollbar{width:6px}.dktv-page .nha-thoi-vu-list::-webkit-scrollbar-track{background:#f1f1f1;border-radius:3px}.dktv-page .nha-thoi-vu-list::-webkit-scrollbar-thumb{background:#c1c1c1;border-radius:3px}.dktv-page .nha-thoi-vu-list::-webkit-scrollbar-thumb:hover{background:#a8a8a8}.dktv-page .nha-thoi-vu-item{display:flex;align-items:flex-start;justify-content:space-between;padding:16px 20px;border-bottom:1px solid #e9ecef;cursor:pointer;transition:all .2s ease;background:white}.dktv-page .nha-thoi-vu-item:hover{background:#f8f9fa;border-left:4px solid #007bff;padding-left:16px}.dktv-page .nha-thoi-vu-item.selected{background:#e3f2fd;border-left:4px solid #007bff;padding-left:16px}.dktv-page .nha-thoi-vu-item:last-child{border-bottom:none}.dktv-page .nha-thoi-vu-info{flex:1;display:flex;flex-direction:column;gap:8px}.dktv-page .nha-thoi-vu-info h4{margin:0;font-size:16px;font-weight:600;color:#2c3e50;line-height:1.3}.dktv-page .nha-thoi-vu-details{display:flex;justify-content:space-between;align-items:center;width:100%}.dktv-page .nha-thoi-vu-code{font-size:12px;color:#6c757d;background:#f8f9fa;padding:4px 8px;border-radius:4px;border:1px solid #e9ecef;flex-shrink:0}.dktv-page .manager-info{margin:4px 0 0;font-size:13px;color:#495057;line-height:1.4}.dktv-page .selection-indicator{flex-shrink:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;margin-left:12px}.dktv-page .checkmark{color:#007bff;font-size:20px;font-weight:700}@media (max-width: 768px){.dktv-page .nha-thoi-vu-modal{width:95%;max-height:70vh}.dktv-page .nha-thoi-vu-item{padding:12px 16px}.dktv-page .nha-thoi-vu-info h4{font-size:15px}.dktv-page .nha-thoi-vu-details{display:flex;justify-content:space-between;align-items:center;width:100%;gap:8px}.dktv-page .nha-thoi-vu-code,.dktv-page .contract-badge{font-size:11px;padding:3px 6px}.dktv-page .manager-info{font-size:12px}}@media (max-width: 480px){.dktv-page .nha-thoi-vu-modal{width:98%;max-height:60vh}.dktv-page .nha-thoi-vu-item{padding:10px 12px}.dktv-page .nha-thoi-vu-info h4{font-size:14px}.dktv-page .nha-thoi-vu-details{display:flex;justify-content:space-between;align-items:center;width:100%;gap:6px}.dktv-page .nha-thoi-vu-code,.dktv-page .contract-badge{font-size:10px;padding:2px 5px;flex-shrink:0}.dktv-page .manager-info{font-size:11px}.dktv-page .selection-indicator{width:28px;height:28px}.dktv-page .checkmark{font-size:18px}}.cropper-modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.9);display:flex;align-items:center;justify-content:center;z-index:10000}.cropper-modal-container{width:98%;height:98%;background:white;border-radius:12px;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 20px 60px #0000004d;position:relative}.cropper-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid #e5e7eb;background:white}.cropper-header h3{margin:0;font-size:18px;font-weight:600;color:#1f2937}.cropper-close-btn{background:none;border:none;font-size:24px;cursor:pointer;color:#6b7280;padding:5px;line-height:1;transition:color .2s}.cropper-close-btn:hover{color:#ef4444}.cropper-image-container{flex:1;display:flex;align-items:center;justify-content:center;padding:10px;background:#f9fafb;position:relative;overflow:hidden;min-height:0}.cropper-image-container,.cropper-image-container *{pointer-events:auto!important}.cropper-image-container .cropper-container{pointer-events:auto!important;touch-action:none!important}.cropper-wrap-box,.cropper-canvas{overflow:visible!important}.cropper-image{max-width:100%;max-height:100%;border-radius:8px;box-shadow:0 4px 20px #00000080;-o-object-fit:contain;object-fit:contain;pointer-events:auto}.cropper-loading{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);color:#374151;font-size:18px;text-align:center;z-index:10}.cropper-spinner{width:40px;height:40px;border:4px solid #e5e7eb;border-top:4px solid #6366f1;border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 10px}.cropper-footer{display:flex;gap:0;padding:0;border-top:1px solid #e5e7eb;background:white}.cropper-controls,.cropper-actions{display:contents}.cropper-controls button,.cropper-actions button{flex:1;height:70px;border:1px solid #d1d5db;color:#fff;font-size:18px;font-weight:700;cursor:pointer;transition:all .2s;margin:0;outline:none;min-width:0;border-radius:0;border-right:none}.cropper-controls button:disabled,.cropper-actions button:disabled{opacity:.6;cursor:not-allowed}#cropper-cancel{border-right:1px solid #d1d5db}#cropper-rotate-left{background:#6366f1;border-color:#6366f1;font-size:16px;border-right:1px solid #5b21b6}#cropper-rotate-right{background:#6366f1;border-color:#6366f1;font-size:16px;border-left:none}#cropper-rotate-left:hover,#cropper-rotate-right:hover{background:#5b21b6;border-color:#5b21b6}#cropper-confirm{background:#10b981;border-color:#10b981;border-right:1px solid #059669}#cropper-confirm:hover{background:#059669;border-color:#059669}#cropper-cancel{background:#ef4444;border-color:#ef4444;border-left:none}#cropper-cancel:hover{background:#dc2626;border-color:#dc2626}.cropper-modal-fullscreen .cropper-modal{background-color:transparent!important}.cropper-image-container .cropper-wrap-box,.cropper-image-container .cropper-canvas,.cropper-image-container .cropper-drag-box,.cropper-image-container .cropper-crop-box,.cropper-image-container .cropper-modal{bottom:0;left:0;position:absolute;right:0;top:0}.cropper-wrap-box,.cropper-canvas{overflow:visible}.cropper-drag-box{background-color:#fff;opacity:0}.cropper-modal{background-color:#000;opacity:.5}.cropper-view-box{display:block;height:100%;outline:1px solid #39f;outline-color:#3399ffbf;overflow:hidden;width:100%}.cropper-dashed{border:0 dashed #eee;display:block;opacity:.5;position:absolute}.cropper-dashed.dashed-h{border-bottom-width:1px;border-top-width:1px;height:calc(100% / 3);left:0;top:calc(100% / 3);width:100%}.cropper-dashed.dashed-v{border-left-width:1px;border-right-width:1px;height:100%;left:calc(100% / 3);top:0;width:calc(100% / 3)}.cropper-center{display:block;height:0;left:50%;opacity:.75;position:absolute;top:50%;width:0}.cropper-center:before,.cropper-center:after{background-color:#eee;content:" ";display:block;position:absolute}.cropper-center:before{height:1px;left:-3px;top:0;width:7px}.cropper-center:after{height:7px;left:0;top:-3px;width:1px}.cropper-face,.cropper-line{display:block;height:100%;opacity:.1;position:absolute;width:100%}.cropper-face{background-color:#fff;left:0;top:0}.cropper-line{background-color:#39f}.cropper-line.line-e{cursor:ew-resize;right:-3px;top:0;width:5px}.cropper-line.line-n{cursor:ns-resize;height:5px;left:0;top:-3px}.cropper-line.line-w{cursor:ew-resize;left:-3px;top:0;width:5px}.cropper-line.line-s{bottom:-3px;cursor:ns-resize;height:5px;left:0}.cropper-modal-container .cropper-point{display:block!important;position:absolute!important;background-color:#39f!important;height:30px!important;width:30px!important;opacity:1!important;border-radius:50%!important;border:3px solid #fff!important;box-shadow:0 4px 12px #0006!important}.cropper-modal-container .cropper-point.point-e{cursor:ew-resize!important;margin-top:-15px!important;right:-15px!important;top:50%!important;width:30px!important;height:30px!important}.cropper-modal-container .cropper-point.point-n{cursor:ns-resize!important;left:50%!important;margin-left:-15px!important;top:-15px!important;width:30px!important;height:30px!important}.cropper-modal-container .cropper-point.point-w{cursor:ew-resize!important;left:-15px!important;margin-top:-15px!important;top:50%!important;width:30px!important;height:30px!important}.cropper-modal-container .cropper-point.point-s{bottom:-15px!important;cursor:ns-resize!important;left:50%!important;margin-left:-15px!important;width:30px!important;height:30px!important}.cropper-modal-container .cropper-point.point-ne{cursor:nesw-resize!important;right:-15px!important;top:-15px!important;width:30px!important;height:30px!important}.cropper-modal-container .cropper-point.point-nw{cursor:nwse-resize!important;left:-15px!important;top:-15px!important;width:30px!important;height:30px!important}.cropper-modal-container .cropper-point.point-sw{bottom:-15px!important;cursor:nesw-resize!important;left:-15px!important;width:30px!important;height:30px!important}.cropper-modal-container .cropper-point.point-se{bottom:-15px!important;cursor:nwse-resize!important;right:-15px!important;width:30px!important;height:30px!important}.cropper-invisible{opacity:0}.cropper-bg{background-image:url(data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABAAAAAQAQMAAAAlPW0iAAAAA3NCSVQICAjb4U/gAAAABlBMVEXMzMz////TjRV2AAAACXBIWXMAAArrAAAK6wGCiw1aAAAAHHRFWHRTb2Z0d2FyZQBBZG9iZSBGaXJld29ya3MgQ1M26LyyjAAAABFJREFUCJlj+M/AgBVhF/0PAH6/D/HkDxOGAAAAAElFTkSuQmCC)}.cropper-hide{display:block;height:0;position:absolute;width:0}.cropper-hidden{display:none!important}.cropper-move{cursor:move}.cropper-crop{cursor:crosshair}.cropper-disabled .cropper-drag-box,.cropper-disabled .cropper-face,.cropper-disabled .cropper-line,.cropper-disabled .cropper-point{cursor:not-allowed}.cropper-modal-overlay{position:fixed!important;top:0!important;left:0!important;width:100%!important;height:100%!important;background:rgba(0,0,0,.8)!important;display:flex!important;align-items:center!important;justify-content:center!important;z-index:10000!important;padding:1vw!important}.image-crop-modal{background:white!important;border-radius:12px!important;width:98vw!important;height:98vh!important;display:flex!important;flex-direction:column!important;overflow:hidden!important;box-shadow:0 20px 60px #0000004d!important;position:relative!important}.image-crop-modal .cropper-header{display:flex!important;justify-content:space-between!important;align-items:center!important;padding:20px!important;border-bottom:1px solid #e5e7eb!important;background:#f9fafb!important;position:relative!important;z-index:1!important}.image-crop-modal .cropper-header h3{margin:0!important;font-size:18px!important;font-weight:600!important;color:#1f2937!important}.image-crop-modal .cropper-close-btn{background:none!important;border:none!important;font-size:24px!important;cursor:pointer!important;color:#6b7280!important;padding:5px!important;line-height:1!important;transition:color .2s!important}.image-crop-modal .cropper-close-btn:hover{color:#ef4444!important}.image-crop-modal .cropper-body{flex:1!important;position:relative!important;overflow:hidden!important;background:#f3f4f6!important;height:calc(100% - 140px)!important}.image-crop-modal .cropper-loading{position:absolute!important;top:0!important;left:0!important;width:100%!important;height:100%!important;display:flex!important;flex-direction:column!important;align-items:center!important;justify-content:center!important;background:rgba(255,255,255,.9)!important;z-index:1000!important;color:#1f2937!important;font-size:16px!important}.image-crop-modal .cropper-spinner{border:4px solid #f3f3f3!important;border-top:4px solid #3b82f6!important;border-radius:50%!important;width:40px!important;height:40px!important;animation:cropper-spin 1s linear infinite!important;margin-bottom:15px!important}@keyframes cropper-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.image-crop-modal .cropper-container{width:100%!important;height:100%!important;display:block!important;padding:5px!important;min-height:300px!important;max-height:calc(100vh - 200px)!important}.image-crop-modal .cropper-container img{display:block!important;max-width:100%!important;max-height:100%!important;width:auto!important;height:auto!important}.cropper-drag-box,.cropper-crop,.cropper-modal{width:auto!important;height:auto!important}.image-crop-modal .cropper-container .cropper-container{width:100%!important;height:100%!important;position:relative!important}.image-crop-modal .cropper-view-box{outline:2px solid #39f!important;outline-color:#3399ffe6!important}.image-crop-modal .cropper-crop-box{border:2px solid #39f!important}.image-crop-modal .cropper-point{background-color:#39f!important;opacity:1!important;width:30px!important;height:30px!important;border-radius:50%!important;border:2px solid #fff!important;box-shadow:0 2px 6px #0000004d!important}.image-crop-modal .cropper-line{background-color:#39f!important;opacity:.6!important}.image-crop-modal .cropper-footer{display:flex!important;justify-content:center!important;align-items:center!important;padding:15px 20px!important;border-top:1px solid #e5e7eb!important;background:#000!important}.image-crop-modal .cropper-controls{display:flex!important;gap:0!important;width:100%!important}.image-crop-modal .cropper-control-btn{flex:1!important;background:#6366f1!important;border:1px solid #4f46e5!important;padding:15px 10px!important;cursor:pointer!important;font-size:16px!important;color:#fff!important;font-weight:500!important;transition:all .2s!important;border-radius:0!important;margin:0!important}.image-crop-modal .cropper-control-btn:first-child{border-top-left-radius:8px!important;border-bottom-left-radius:8px!important}.image-crop-modal .cropper-control-btn:last-child{border-top-right-radius:8px!important;border-bottom-right-radius:8px!important}.image-crop-modal .cropper-control-btn:hover{background:#5b21b6!important;border-color:#5b21b6!important}.image-crop-modal .cropper-crop-btn{background:#10b981!important;border-color:#059669!important}.image-crop-modal .cropper-crop-btn:hover{background:#059669!important;border-color:#047857!important}.image-crop-modal .cropper-cancel-btn{background:#ef4444!important;border-color:#dc2626!important}.image-crop-modal .cropper-cancel-btn:hover{background:#dc2626!important;border-color:#b91c1c!important}@media (max-width: 768px){.image-crop-modal{width:98vw!important;height:98vh!important}.image-crop-modal .cropper-actions{width:100%!important;justify-content:center!important}.image-crop-modal .cropper-header{padding:15px!important}.image-crop-modal .cropper-container{padding:10px!important}.image-crop-modal .cropper-body{height:calc(100% - 160px)!important}}@media (max-width: 768px){.cropper-modal-container{width:95vw;height:95vh;border-radius:12px}.cropper-header{padding:15px}.cropper-header h3{font-size:16px}.cropper-image-container{padding:5px}.cropper-controls button,.cropper-actions button{height:60px;font-size:16px}#cropper-rotate-left,#cropper-rotate-right{font-size:24px}}@media (max-width: 480px){.cropper-modal-container{width:98vw;height:98vh;border-radius:12px}.cropper-header{padding:10px}.cropper-header h3{font-size:14px}.cropper-controls button,.cropper-actions button{height:50px;font-size:14px}#cropper-rotate-left,#cropper-rotate-right{font-size:20px}}.cropper-image-container .cropper-canvas img,.cropper-image-container .cropper-canvas canvas{transform-origin:center center!important}.cropper-image-container .cropper-wrap-box{transform-origin:center center!important}.cropper-image-container .cropper-container{width:100%!important;height:100%!important;position:relative!important}.dktv-page .candidate-form{display:flex;flex-direction:column;gap:20px}.dktv-page .form-group{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.dktv-page .form-group label{display:block;margin-bottom:6px;font-weight:500;color:#495057;font-size:14px}.dktv-page .required{color:#dc3545}.dktv-page .form-group input,.dktv-page .form-group select,.dktv-page .form-group textarea{width:100%;padding:10px 12px;border:1px solid #ced4da;border-radius:6px;font-size:14px;transition:border-color .3s,box-shadow .3s;box-sizing:border-box}.dktv-page .form-group input:focus,.dktv-page .form-group select:focus,.dktv-page .form-group textarea:focus{outline:none;border-color:#007bff;box-shadow:0 0 0 2px #007bff40}.dktv-page .form-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.dktv-page .file-input{padding:8px 12px!important;background:white;cursor:pointer;margin-bottom:10px}.dktv-page .file-input::-webkit-file-upload-button{background:#007bff;color:#fff;border:none;padding:6px 12px;border-radius:4px;cursor:pointer;margin-right:10px;font-size:13px}.dktv-page .file-input::-webkit-file-upload-button:hover{background:#0056b3}.dktv-page .avatar-preview{margin-top:10px;text-align:center;display:flex;align-items:center;justify-content:center;height:140px}.dktv-page .avatar-preview img{height:120px;width:auto;border-radius:8px;border:1px solid #dee2e6;-o-object-fit:contain;object-fit:contain}.dktv-page .avatar-preview img,.dktv-page .image-preview img{max-width:100%;max-height:150px;border-radius:6px;border:1px solid #ddd}.dktv-page .upload-section{margin:20px 0;padding:20px;background:#f8f9fa;border-radius:8px;border:2px dashed #dee2e6}.dktv-page .upload-section h4{margin:0 0 20px;color:#495057;font-size:16px;font-weight:600}.dktv-page .upload-row{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px}.upload-row .form-group{text-align:center;display:flex;flex-direction:column;min-height:200px}.upload-row .dktv-page .form-group label{display:block;margin-bottom:10px;font-weight:500;color:#495057;flex-shrink:0}.upload-row .file-input{margin-bottom:15px;flex-shrink:0}.dktv-page .avatar-preview,.dktv-page .image-preview{width:100%;height:140px;margin:10px auto 0;border-radius:6px;overflow:hidden;flex:1;display:flex;align-items:center;justify-content:center}.dktv-page .qr-input{font-family:monospace;font-size:13px;resize:vertical;height:40px;max-height:80px;min-height:80px}.dktv-page .qr-parsed-info{margin-top:10px;padding:12px;background:#d4edda;border:1px solid #c3e6cb;border-radius:6px;font-size:13px}.dktv-page .qr-parsed-info h4{margin:0 0 8px;color:#155724;font-size:14px;font-weight:600}.dktv-page .qr-parsed-info>div{margin-bottom:4px;color:#155724}.dktv-page .qr-parsed-info>div:last-child{margin-bottom:0}.dktv-page .address-mode-container{display:flex;align-items:center;gap:15px;margin-bottom:8px}.dktv-page .address-mode-container label{margin:0;font-weight:500;color:#2c3e50}.dktv-page .address-mode-radios{display:flex;gap:20px;margin-top:8px}.dktv-page .radio-label{display:flex;align-items:center;gap:6px;font-size:14px;font-weight:400!important;color:#495057!important;cursor:pointer}.dktv-page .radio-label input[type=radio]{margin:0;width:auto;height:auto}.dktv-page .form-actions{display:flex;gap:12px;justify-content:flex-end;margin-top:30px;padding-top:20px;border-top:1px solid #dee2e6}@media (max-width: 768px){.dktv-page .form-row,.dktv-page .form-actions{flex-direction:column}.dktv-page .address-mode-container{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 576px){.dktv-page .upload-row{grid-template-columns:1fr}.upload-row .form-group{min-height:auto}.dktv-page .avatar-preview,.dktv-page .image-preview{max-width:200px}}.dktv-page .actions-cell{display:flex;justify-content:center;align-items:center}.dktv-page .action-btn{padding:6px 8px;border:none;border-radius:4px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center}.dktv-page .action-btn.delete-btn{background:#dc3545;color:#fff}.dktv-page .action-btn.delete-btn:hover:not(:disabled){background:#c82333;transform:scale(1.05)}.dktv-page .action-btn.delete-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.5}.delete-btn.disabled{background:#6c757d!important;color:#fff!important;opacity:.5;cursor:not-allowed!important}.delete-btn.disabled:hover{background:#6c757d!important}.dktv-page .submit-btn{background:#28a745;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s;min-width:120px}.dktv-page .submit-btn:hover:not(:disabled){background:#218838}.dktv-page .submit-btn:disabled{background:#6c757d;cursor:not-allowed;opacity:.6}.dktv-page .cancel-btn{background:#6c757d;color:#fff;border:none;padding:12px 24px;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s;min-width:80px}.dktv-page .cancel-btn:hover{background:#5a6268}.dktv-page .update-btn{padding:10px 20px;background:#6c757d;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:not-allowed;transition:all .3s;opacity:.6}.update-btn.has-changes{background:#28a745;cursor:pointer;opacity:1}.update-btn.has-changes:hover{background:#218838}.dktv-page .delete-btn{padding:10px 20px;background:#dc3545;color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .3s}.dktv-page .delete-btn:hover{background:#c82333}.dktv-page .attendance-status-present{display:flex;flex-direction:column;align-items:center;gap:2px;background:#caeeda;color:#020f05;padding:4px 8px;border-radius:4px;font-size:12px;border:1px solid #c3e6cb;max-width:100%;min-height:32px;text-align:center}.attendance-status-present .attendance-full-text{display:flex;flex-direction:column;align-items:center;line-height:1.2;max-width:200px}.dktv-page .attendance-line-1{display:flex;align-items:center;gap:4px;font-weight:600;margin-bottom:2px;color:#0e709e}.dktv-page .attendance-line-2{font-size:12px;opacity:.9;text-align:center;color:#0e709e}.action-btn.attendance-btn{background:#007bff;color:#fff;border:none;padding:6px 12px;border-radius:4px;font-size:13px;cursor:pointer;display:flex;align-items:center;gap:6px;transition:background-color .2s}.action-btn.attendance-btn:hover{background:#0056b3}.action-btn.attendance-btn:disabled{background:#6c757d;cursor:not-allowed}.dktv-page .edit-btn{background:#007bff!important;color:#fff!important}.dktv-page .edit-btn:hover{background:#0056b3!important}.dktv-page .mobile-actions-cell{display:flex;justify-content:center;align-items:center}.mobile-actions-cell .action-btn{padding:4px;margin-right:2px;margin-bottom:2px;display:inline-flex}.mobile-actions-cell .dktv-page .action-btn svg{width:14px;height:14px}.dktv-page .mobile-actions-column{display:flex;flex-direction:column;gap:6px;justify-content:center;align-items:center;height:100%;padding:2px}.mobile-actions-column .mobile-action-buttons{display:flex;flex-direction:column;gap:6px;align-items:center;width:100%}.mobile-actions-column .mobile-action-buttons .action-btn{width:100%;max-width:75px;padding:5px 4px;font-size:10px;display:flex;align-items:center;justify-content:center;gap:3px;border-radius:4px;border:none;cursor:pointer;transition:all .2s ease;text-align:center}.mobile-actions-column .mobile-action-buttons .dktv-page .action-btn svg{width:12px;height:12px;flex-shrink:0}.mobile-actions-column .mobile-action-buttons .dktv-page .action-btn span{font-size:10px;font-weight:500}@media (max-width: 768px){.dktv-page .submit-btn,.dktv-page .cancel-btn{width:100%}.dktv-page .attendance-status-present{flex-direction:column;align-items:center;gap:1px;padding:3px 6px;min-height:auto;text-align:center}.attendance-status-present .attendance-full-text{max-width:100px;font-size:9px;line-height:1.5;align-items:center}.dktv-page .attendance-line-1{font-size:11px;font-weight:600;margin-bottom:0;gap:2px}.dktv-page .attendance-line-2{font-size:9px;opacity:.9;text-align:center}.action-btn.attendance-btn{font-size:12px;padding:5px 10px}}@media (max-width: 480px){.dktv-page .mobile-actions-cell{padding:6px 4px!important}.mobile-actions-cell .action-btn{padding:3px;margin:1px}}.dktv-page .pagination-container{flex-shrink:0;border-radius:6px;box-shadow:0 2px 4px #0000001a;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.dktv-page .pagination-info{font-size:14px;color:#6c757d;font-weight:500}.dktv-page .pagination-controls{display:flex;gap:1px;align-items:center}.dktv-page .pagination-btn{padding:8px 12px;border:1px solid #dee2e6;background:white;color:#495057;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s;min-width:40px}.dktv-page .pagination-btn:hover:not(:disabled){background:#f8f9fa;border-color:#6c757d}.dktv-page .pagination-btn.active{background:#007bff;color:#fff;border-color:#007bff}.dktv-page .pagination-btn:disabled{background:#e9ecef;color:#6c757d;cursor:not-allowed;opacity:.5}@media (max-width: 992px){.dktv-page .pagination-container{flex-direction:column;gap:10px;text-align:center}}@media (max-width: 768px){.dktv-page .pagination-container{padding:12px 15px;flex-direction:column;gap:10px;text-align:center}.dktv-page .pagination-controls{justify-content:center;flex-wrap:nowrap}.dktv-page .pagination-btn{padding:6px 10px;font-size:12px;min-width:35px}}@media (max-width: 480px){.dktv-page .pagination-container{padding:10px}.dktv-page .pagination-controls{gap:1px}.dktv-page .pagination-btn{padding:6px 10px;font-size:12px}}@media (max-width: 1200px){.dktv-page .candidates-table th:nth-child(4),.dktv-page .candidates-table td:nth-child(4){width:250px}}@media (max-width: 992px){.dktv-page .dktv-controls{flex-direction:column;align-items:stretch}.dktv-page .search-container{min-width:auto}.dktv-page .form-row{flex-direction:column}.dktv-page .pagination-container{flex-direction:column;gap:10px;text-align:center}}@media (max-width: 768px){.dktv-page .dktv-container{max-width:100vw;overflow-x:hidden;overflow-y:auto;height:calc(100vh - 50px);padding:10px;display:flex;flex-direction:column}.dktv-page .app-container{width:100vw;max-width:100vw;margin:0;box-sizing:border-box;padding:0 8px}.dktv-page .dktv-header{padding:8px 0;box-shadow:none;border-radius:0;background:white}.dktv-page .dktv-header h2{display:none!important}.dktv-page .dktv-controls{display:flex!important;flex-direction:row!important;align-items:center!important;width:100%!important;padding:0!important;justify-content:space-between!important;flex-direction:column;gap:10px}.dktv-page .search-container{flex:1!important;min-width:0!important;margin:0!important;max-width:calc(100% - 100px)!important;min-width:100%}.dktv-page .search-input{font-size:14px!important;padding:8px 8px 8px 36px!important;border-radius:6px!important;width:100%!important}.dktv-page .nha-thoi-vu-filter{display:none!important;width:100%}.dktv-page .add-candidate-btn{min-width:40px!important;max-width:40px!important;height:40px!important;padding:0!important;background:#28a745!important;border-radius:6px!important;color:transparent!important;display:flex!important;align-items:center!important;gap:0!important;flex-shrink:0!important;overflow:hidden!important;white-space:nowrap!important;position:relative!important;width:100%;justify-content:center}.dktv-page .add-candidate-btn>svg{width:24px!important;height:24px!important;color:#fff!important;flex-shrink:0!important;position:absolute!important;top:50%!important;left:50%!important;transform:translate(-50%,-50%)!important}.dktv-page .results-info{padding:12px 15px;font-size:13px}.dktv-page .candidates-table-container{overflow-x:auto;margin-bottom:15px;flex:1;display:flex;flex-direction:column;overflow:hidden}.dktv-page .desktop-table{display:none!important}.dktv-page .mobile-table{display:table!important}.dktv-page .form-actions{flex-direction:column}.dktv-page .submit-btn,.dktv-page .cancel-btn{width:100%}.dktv-page .address-mode-container{flex-direction:column;align-items:flex-start;gap:8px}}@media (max-width: 576px){.dktv-page .modal-content{margin:10px;max-height:calc(100vh - 20px)}.dktv-page .modal-header,.dktv-page .candidate-form{padding:15px}.dktv-page .dktv-header h2{font-size:18px}.dktv-page .upload-row{grid-template-columns:1fr}.upload-row .form-group{min-height:auto}.dktv-page .avatar-preview,.dktv-page .image-preview{max-width:200px}}@media (max-width: 480px){.dktv-page .dktv-container{padding:10px}.dktv-page .dktv-header{padding:15px}.dktv-page .results-info{padding:10px 15px;font-size:13px}.dktv-page .pagination-container{padding:10px}.dktv-page .pagination-controls{gap:1px}.dktv-page .pagination-btn{padding:6px 10px;font-size:12px}.dktv-page .status-badge{font-size:10px;padding:3px 6px;min-width:60px}.dktv-page .candidate-name{font-size:13px;font-weight:600}}.fingerprint-list-page *{margin:0;padding:0;box-sizing:border-box}.fingerprint-list-page{font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;color:#333}.fingerprint-list-page .container{margin:0 auto;background:white;height:calc(100vh - 50px);display:flex;flex-direction:column;overflow:hidden;border-radius:10px;box-shadow:0 4px 20px #0000001a}.layout-container{display:flex;flex-direction:row;gap:20px;height:calc(100vh - 50px);flex:1;overflow:hidden}.left-panel{flex:0 0 35%;display:flex;flex-direction:column;padding:20px;background:#f8f9fa;border-radius:10px 0 0 10px;height:calc(100vh - 50px);overflow:hidden}.right-panel{flex:1;display:flex;flex-direction:column;height:calc(100vh - 50px);overflow:hidden}.fingerprint-list-page header{text-align:center;background:transparent;z-index:200;padding:0;box-shadow:none;flex-shrink:0}.fingerprint-list-page header h1{color:#333;font-size:clamp(24px,4vw,36px);font-weight:600}.fingerprint-list-page .search-container{display:flex;justify-content:center;align-items:center;gap:20px;max-width:90%;margin:0 auto 2px}.fingerprint-list-page .search-input-wrapper{position:relative;flex:1;display:flex;align-items:center}.fingerprint-list-page .search-container input{flex:1;width:100%;padding:12px 50px 12px 16px;border:2px solid #ddd;border-radius:10px;font-size:16px;transition:all .3s ease}.fingerprint-list-page .search-container input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.fingerprint-list-page .clear-search-btn{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;color:#999;font-size:18px;font-weight:700;cursor:pointer;padding:5px;border-radius:50%;transition:all .2s ease;width:30px;height:30px;display:none;align-items:center;justify-content:center;line-height:1}.fingerprint-list-page .clear-search-btn:hover{background:rgba(220,53,69,.1);color:#dc3545}.fingerprint-list-page .clear-search-btn.show{display:flex}.statistics-container{display:flex;flex-direction:column;gap:15px;margin:10px 0;width:100%}.stat-card{flex:1;max-width:none;background:linear-gradient(135deg,#f8f9fa 0%,#e9ecef 100%);border:2px solid #dee2e6;border-radius:15px;padding:10px;text-align:center;box-shadow:0 4px 15px #0000001a;transition:all .3s ease;gap:0px;cursor:pointer;position:relative;overflow:hidden;display:flex;flex-direction:column;justify-content:center;align-items:center}.stat-card:before{content:"";position:absolute;top:0;left:-100%;width:100%;height:100%;background:linear-gradient(90deg,transparent,rgba(255,255,255,.3),transparent);transition:left .5s}.stat-card:hover:before{left:100%}.stat-card:hover{transform:translateY(-5px);box-shadow:0 8px 25px #00000026;border-color:#667eea;background:linear-gradient(135deg,#ffffff 0%,#f8f9fa 100%)}.stat-label{font-size:25px;color:#666;font-weight:700}.stat-value{font-size:45px;font-weight:700;color:#333;line-height:1.2}.stat-remaining{font-size:30px;color:#888;font-weight:400}#cardStatistics:hover{border-color:#28a745}#cardStatistics .stat-value{color:#28a745}#fingerprintStatistics:hover{border-color:#007bff}#fingerprintStatistics .stat-value{color:#007bff}#tableContainer{flex:1;display:flex;flex-direction:column;height:calc(100vh - 90px);position:relative;overflow:hidden;border-radius:0 10px 10px 0;box-shadow:0 4px 8px #0000001a;margin-right:20px}.table-header{flex-shrink:0;background:#6b73ff;border-radius:20px 20px 0 0!important;overflow:hidden}.table-header table{width:100%;border-collapse:separate;border-spacing:0;border-radius:10px 10px 0 0;overflow:hidden}.table-header thead tr{display:table-row}.table-header th{background:#6b73ff;color:#fff;text-align:center;vertical-align:middle;font-weight:600;font-size:16px;padding:12px;border:none;height:45px}.table-header th:first-child{border-top-left-radius:10px!important;height:45px;width:120px;min-width:120px}.table-header th:last-child{border-top-right-radius:10px!important;width:80px;min-width:80px;height:60px}.table-header .col-ma-nhan-vien{width:140px;min-width:140px}.table-header .col-ho-ten{width:200px;min-width:200px}.table-header .col-ngay-sinh{width:140px;min-width:140px}.table-header .col-cccd{width:150px;min-width:150px}.table-header .col-nha-thoi-vu{width:100px;min-width:100px}.table-header .col-bo-qua{width:80px;min-width:80px}.table-header thead tr th{background:#6b73ff!important}.th-content{display:flex;justify-content:center;align-items:center;width:100%;position:relative}.th-content span{text-align:center;flex:1;padding-right:40px}.vendor-filter-icon{cursor:pointer;padding:5px;border-radius:8px;transition:all .3s ease;color:#fff;opacity:.8;position:absolute;right:10px}.vendor-filter-icon svg{width:20px;height:20px}.vendor-filter-icon .filter-icon{display:block!important}.vendor-filter-icon .filter-active-icon,.vendor-filter-icon.filtering .filter-icon{display:none!important}.vendor-filter-icon.filtering .filter-active-icon{display:block!important}.vendor-filter-icon:hover{opacity:1;background:rgba(255,255,255,.2);transform:scale(1.1)}.vendor-filter-icon.filtering{opacity:1!important}.vendor-filter-icon.filtering:hover{border:3px solid #ffc107!important;transform:scale(1.1);box-shadow:0 0 15px #ffc107}.hidden{display:none!important}.vendor-dropdown{position:absolute;top:70px;right:20px;background:white;border:2px solid #667eea;border-radius:12px;box-shadow:0 10px 30px #0003;z-index:1000;min-width:500px;max-height:400px;overflow:hidden}.vendor-dropdown.hidden{display:none}.vendor-dropdown-header{background:#667eea;color:#fff;padding:15px 20px;font-weight:600;font-size:18px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:15px}.date-picker-container{display:flex;align-items:center;gap:10px;flex:1}.date-picker-container label{font-size:14px;font-weight:500;white-space:nowrap}.date-filter-input{padding:8px 12px;border:2px solid #fff;border-radius:6px;background:white;color:#333;font-size:14px;font-weight:500;min-width:150px;transition:all .3s ease}.date-filter-input:focus{outline:none;border-color:#ffc107;box-shadow:0 0 0 2px #ffc10733}.clear-date-btn{background:#dc3545;color:#fff;border:none;width:24px;height:24px;border-radius:50%;cursor:pointer;font-size:16px;font-weight:700;display:flex;align-items:center;justify-content:center;transition:all .3s ease}.clear-date-btn:hover{background:#c82333;transform:scale(1.1)}.clear-filter-btn{background:linear-gradient(135deg,#ffc107 0%,#e0a800 100%);color:#212529;border:none;padding:6px 12px;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;transition:all .3s ease}.clear-filter-btn:hover{background:linear-gradient(135deg,#e0a800 0%,#d39e00 100%);transform:translateY(-2px);box-shadow:0 4px 12px #ffc1074d}.close-dropdown{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:background .3s;font-weight:700}.close-dropdown:hover{background:rgba(255,255,255,.2)}.filter-tabs{display:flex;background:#f8f9fa;border-bottom:1px solid #dee2e6;height:45px}.tab-btn{flex:1;padding:10px 15px;background:none;border:none;font-size:14px;font-weight:600;cursor:pointer;transition:all .3s ease;color:#6c757d;border-bottom:2px solid transparent}.tab-btn:hover{background:#e9ecef;color:#495057}.tab-btn.active{background:white;color:#667eea;border-bottom-color:#667eea}.filter-tab-content{display:none}.filter-tab-content.active{display:block}.vendor-options,.evenodd-options,.category-options{max-height:300px;overflow-y:auto;padding:10px 0}.vendor-option,.evenodd-option,.category-option{display:flex;align-items:center;padding:10px 15px;cursor:pointer;transition:background .2s;border-bottom:1px solid #f0f0f0}.vendor-option:hover,.evenodd-option:hover,.category-option:hover{background:#f8f9fa}.vendor-option:last-child,.evenodd-option:last-child,.category-option:last-child{border-bottom:none}.vendor-option input[type=radio],.evenodd-option input[type=radio],.category-option input[type=checkbox]{margin-right:10px;transform:scale(1.2)}.vendor-option label,.evenodd-option label,.category-option label{flex:1;font-size:14px;font-weight:500;color:#333;cursor:pointer}.filtered-note{font-size:12px;color:#667eea;font-weight:400;font-style:italic}.no-vendors-message{padding:15px;text-align:center;color:#6c757d;font-style:italic;font-size:14px;background:#f8f9fa;border-radius:8px;margin:10px;border:1px solid #e9ecef}.vendor-option.selected,.evenodd-option.selected,.category-option.selected{background:#e3f2fd;border-left:4px solid #667eea}.table-body{flex:1;overflow-y:auto;overflow-x:hidden;background:white;min-height:0;max-height:calc(100vh - 155px)}.table-body table{width:100%;border-collapse:collapse}.table-body tbody tr{display:table-row}.table-body td{padding:0;vertical-align:middle;text-align:center;border-bottom:1px solid #eee;font-size:14px;height:50px}.col-trangthai,.table-body td:nth-child(1){width:120px;min-width:120px;text-align:center;vertical-align:middle;padding:0}.col-ma-nhan-vien,.table-body td:nth-child(2){width:140px;min-width:140px;text-align:center;vertical-align:middle;padding:8px;font-weight:700;color:#333}.col-ho-ten,.table-body td:nth-child(3){width:200px;min-width:200px;text-align:center;vertical-align:middle;padding:8px;font-weight:500;color:#333}.col-ngay-sinh,.table-body td:nth-child(4){width:140px;min-width:140px;text-align:center;vertical-align:middle;padding:8px;color:#666;font-size:13px;white-space:nowrap}.col-cccd,.table-body td:nth-child(5){width:150px;min-width:150px;text-align:center;vertical-align:middle;padding:8px;color:#666;font-size:13px;font-style:italic}.col-nha-thoi-vu,.table-body td:nth-child(6){width:100px;min-width:100px;text-align:center;vertical-align:middle;padding:8px}.col-bo-qua,.table-body td:nth-child(7){width:80px;min-width:80px;text-align:center;vertical-align:middle;padding:8px}.table-body tr:nth-child(2n){background-color:#f8f9fa}.table-body tr:hover{background-color:#e3f2fd}.col-trangthai{text-align:center;padding:0}@media (min-width: 769px){.desktop-only{display:table-cell}.mobile-only{display:none}}@media (max-width: 768px){.desktop-only{display:none!important}.mobile-only{display:table-cell!important}}.col-thongtin{padding:0}.action-container{display:flex;justify-content:center;align-items:center;padding:8px;height:50px;min-height:50px}.btn-fingerprint{background:#28a745;color:#fff;border:none;padding:8px 12px;border-radius:10px;font-size:12px;font-weight:600;cursor:pointer;transition:all .2s ease;width:100px;height:35px;text-align:center;line-height:1;white-space:nowrap;display:flex;align-items:center;justify-content:center}.btn-fingerprint:hover{background:#218838;transform:translateY(-1px);box-shadow:0 2px 8px #28a7454d}.btn-fingerprint.completed{background:#6c757d;cursor:not-allowed}.employee-info-container{display:flex;justify-content:space-between;align-items:flex-start;padding:10px 15px;min-height:100px;gap:15px}.employee-details{flex:1;display:flex;flex-direction:column;gap:0px;text-align:left}.employee-id{font-size:18px;font-weight:700;color:#333;margin-bottom:2px;text-align:left}.employee-name{font-size:23px;color:#333;font-weight:500;line-height:24px;padding-bottom:5px;text-align:left}.employee-birth{font-size:14px;color:#666;text-align:left}.employee-cccd{font-size:18px;color:#666;font-weight:400;font-style:italic;text-align:left}.employee-actions{display:flex;flex-direction:column;justify-content:space-between;align-items:flex-end;min-height:100px;padding:5px 0;text-align:right}.skip-action{display:flex;justify-content:flex-end;margin-bottom:5px;text-align:right}.btn-skip-small{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:15px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:70px}.btn-skip-small:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 2px 8px #dc35454d}.skip-status{background:#f8d7da;color:#721c24;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;border:1px solid #f5c6cb}.vendor-code{font-size:16px;color:#007bff;font-weight:700;padding:4px 12px;background:#e7f3ff;border-radius:12px;border:1px solid #b3d7ff;margin-top:auto;text-align:center}.btn-action{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff;border:none;padding:12px 20px;border-radius:30px;cursor:pointer;font-size:40px;transition:all .2s;width:180px;height:140px;display:flex;align-items:center;justify-content:center}.btn-action:hover{transform:translateY(-1px);box-shadow:0 4px 8px #28a7454d}.btn-skip{background:linear-gradient(135deg,#ffc107 0%,#ffb300 100%);color:#333;border:none;padding:12px 20px;border-radius:8px;cursor:pointer;font-size:28px;transition:all .2s;font-weight:600;width:180px;height:80px;display:flex;align-items:center;justify-content:center}.btn-skip:hover{background:linear-gradient(135deg,#ffb300 0%,#ffa000 100%);transform:translateY(-1px);box-shadow:0 4px 8px #ffc10766}.btn-edit{background:linear-gradient(135deg,#6c757d 0%,#495057 100%);color:#fff;border:none;padding:6px 10px;border-radius:50%;cursor:pointer;font-size:20px;transition:all .2s;width:40px;height:40px;display:flex;align-items:center;justify-content:center}.btn-edit:hover{background:linear-gradient(135deg,#495057 0%,#343a40 100%);transform:translateY(-1px) scale(1.1);box-shadow:0 4px 8px #6c757d66}.info-container{position:relative;width:100%}.status-container{display:flex;flex-direction:column;align-items:center;position:relative;gap:40px}.status-with-edit{display:flex;align-items:center;gap:10px}.da-lay-vantay,.da-bo-qua{font-weight:700;font-size:30px}.da-lay-vantay{color:#28a745}.da-bo-qua{color:#ff6b35}.pagination{display:flex;justify-content:center;align-items:center;gap:10px;background:white;position:sticky;bottom:0;z-index:100;border-top:1px solid #eee;box-shadow:0 -2px 10px #0000001a;flex-shrink:0;border-radius:0 0 10px 10px;padding:10px;height:60px}.pagination button{padding:8px 16px;border:1px solid #667eea;background:white;cursor:pointer;border-radius:6px;font-size:14px;font-weight:600;color:#667eea;transition:all .3s ease;min-width:70px;position:relative;z-index:101;pointer-events:auto;-webkit-user-select:none;-moz-user-select:none;user-select:none}.pagination button:enabled:hover{background:#667eea;color:#fff;transform:translateY(-2px);box-shadow:0 4px 12px #667eea4d}.pagination button:disabled{opacity:.4;cursor:not-allowed;background:#f8f9fa!important;color:#6c757d!important;border-color:#dee2e6!important;pointer-events:none;transform:none!important;box-shadow:none!important}#pageInfo{font-size:14px;font-weight:600;color:#333;background:#f8f9fa;border-radius:6px;padding:8px 16px;border:1px solid #dee2e6}.loading{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#00000080;z-index:9999;display:flex;flex-direction:column;justify-content:center;align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.loading p{margin:0;font-size:16px;font-weight:500;color:#fff;text-shadow:0 1px 2px rgba(0,0,0,.5)}.spinner{border:4px solid rgba(255,255,255,.3);border-top:4px solid #fff;border-radius:50%;width:60px;height:60px;animation:spin 1s linear infinite;margin-bottom:20px;box-shadow:0 4px 8px #0000001a}.fingerprint-list-page .modal{position:fixed;z-index:1000;left:0;top:0;width:100%;height:100%;overflow:auto;background-color:#0006;display:flex;justify-content:center;align-items:center}.fingerprint-list-page .modal-content{background-color:#fefefe;margin:15% auto;padding:15px;border:none;width:95%;max-width:600px;border-radius:20px;box-shadow:0 20px 60px #0000004d;animation:modalSlideIn .3s ease-out}.fingerprint-list-page .modal-content h3{color:#333;margin-bottom:20px;font-size:36px;text-align:center}.fingerprint-list-page .modal-content p{color:#666;margin-bottom:30px;font-size:24px;text-align:center;line-height:1.4}.fingerprint-list-page .modal-content .employee-code-highlight{font-size:42px;font-weight:700;color:#007bff;padding:0 16px;display:inline-block;margin:1px}.fingerprint-list-page .modal-buttons{display:flex;justify-content:center;gap:20px;margin-top:30px}.fingerprint-list-page .btn-confirm,.fingerprint-list-page .btn-cancel{padding:15px 30px;border:none;border-radius:8px;font-size:20px;font-weight:600;cursor:pointer;transition:all .3s ease;min-width:120px}.fingerprint-list-page .btn-confirm{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff}.fingerprint-list-page .btn-confirm:hover{background:linear-gradient(135deg,#20c997 0%,#17a2b8 100%);transform:translateY(-2px);box-shadow:0 4px 15px #28a7454d}.fingerprint-list-page .btn-cancel{background:linear-gradient(135deg,#6c757d 0%,#495057 100%);color:#fff}.fingerprint-list-page .btn-cancel:hover{background:linear-gradient(135deg,#495057 0%,#343a40 100%);transform:translateY(-2px);box-shadow:0 4px 15px #6c757d4d}.fingerprint-list-page .skip-input-group{margin:20px 0}.fingerprint-list-page .skip-input-group label{display:block;margin-bottom:15px;font-weight:600;color:#333;font-size:20px}.fingerprint-list-page .skip-input-group input{width:100%;padding:15px;border:2px solid #ddd;border-radius:8px;font-size:18px;transition:border-color .3s}.fingerprint-list-page .skip-input-group input:focus{border-color:#667eea;outline:none;box-shadow:0 0 0 3px #667eea1a}.fingerprint-list-page .skip-input-group input::-moz-placeholder{color:#999;font-style:italic}.fingerprint-list-page .skip-input-group input::placeholder{color:#999;font-style:italic}.fingerprint-list-page .quick-reason-buttons{display:flex;gap:10px;margin-bottom:15px;flex-wrap:wrap}.fingerprint-list-page .quick-reason-btn{padding:8px 16px;border:2px solid #667eea;background:white;color:#667eea;border-radius:20px;cursor:pointer;font-size:16px;font-weight:500;transition:all .3s ease}.fingerprint-list-page .quick-reason-btn:hover{background:#667eea;color:#fff;transform:translateY(-1px)}.fingerprint-list-page .quick-reason-btn.selected{background:#667eea;color:#fff}.fingerprint-list-page .quick-reason-btn.selected:hover{background:#5a67d8}@keyframes modalSlideIn{0%{transform:translateY(-50px);opacity:0}to{transform:translateY(0);opacity:1}}@media (max-width: 1024px) and (min-width: 769px){.left-panel{flex:0 0 40%}.stat-label{font-size:20px}.stat-value{font-size:36px}.stat-remaining{font-size:24px}}@media (max-width: 768px){.fingerprint-list-page .container{height:calc(100vh - 50px)}.layout-container{flex-direction:column;gap:10px;height:calc(100vh - 50px)}.left-panel{flex:0 0 auto;padding:15px 15px 0;background:white;border-radius:10px;height:auto;max-height:250px;overflow:hidden}.right-panel{flex:1;min-height:0;height:calc(100vh - 320px)}#tableContainer{border-radius:10px;margin-right:0;height:100%;padding:0 10px}.table-body{max-height:calc(100vh - 350px)}.fingerprint-list-page header{background:white;box-shadow:0 2px 10px #0000001a;border-radius:10px}header h1{font-size:28px}.fingerprint-list-page .search-container{flex-direction:column;gap:10px}.fingerprint-list-page .search-container input{font-size:18px;padding:8px 40px 8px 12px}.statistics-container{flex-direction:row;gap:10px}.stat-card{flex:1;min-height:100px}.stat-label{font-size:14px}.stat-value{font-size:28px}.stat-remaining{font-size:14px}.table-header th{font-size:20px;padding:10px 8px;height:50px}.vendor-filter-icon svg{width:24px;height:24px}.th-content span{padding-right:30px}.vendor-dropdown{min-width:92vw;max-width:92vw;right:18px;top:60px}.vendor-dropdown-header{padding:12px 15px;font-size:16px;flex-direction:row;align-items:center;gap:10px;flex-wrap:wrap}.date-picker-container{flex-direction:row;align-items:center;gap:8px;flex:1;min-width:200px}.date-picker-container label{font-size:14px;min-width:auto}.date-filter-input{min-width:120px;font-size:14px;padding:8px 10px}.clear-date-btn{width:22px;height:22px;font-size:14px}.clear-filter-btn{padding:6px 10px;font-size:14px}.close-dropdown{width:25px;height:25px;font-size:25px}.filter-tabs{height:40px}.tab-btn{padding:8px 12px;font-size:12px}.vendor-option,.evenodd-option,.category-option{padding:10px 12px}.vendor-option label,.evenodd-option label,.category-option label{font-size:16px}.filtered-note{font-size:12px}.no-vendors-message{font-size:14px;padding:12px;margin:10px}.col-trangthai,.table-body td:nth-child(1){width:100px;min-width:100px}.col-thongtin,.table-body td:nth-child(2){width:calc(100% - 100px)}.table-header th:first-child{width:100px;min-width:100px}.table-header th.mobile-only{width:calc(100% - 100px)}.btn-fingerprint{width:80px;height:60px;font-size:16px;padding:4px 8px}.action-container{padding:8px 4px;min-height:70px}.btn-action{width:120px;height:80px;font-size:20px}.btn-skip{width:120px;height:50px;font-size:18px}.pagination{gap:8px;padding:8px}.pagination button{padding:6px 12px;font-size:12px;min-width:60px}#pageInfo{font-size:12px;padding:6px 12px}}.col-nha-thoi-vu{font-size:16px;color:#007bff;font-weight:700}.col-bo-qua .btn-skip-small{background:#dc3545;color:#fff;border:none;padding:6px 12px;border-radius:15px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:70px}.col-bo-qua .btn-skip-small:hover{background:#c82333;transform:translateY(-1px);box-shadow:0 2px 8px #dc35454d}.col-bo-qua .skip-status{background:#f8d7da;color:#721c24;padding:4px 8px;border-radius:12px;font-size:12px;font-weight:500;border:1px solid #f5c6cb}@media (max-width: 768px){.btn-fingerprint{white-space:pre-line!important;line-height:1.1!important;height:55px!important;width:85px!important;font-size:13px!important}.action-container{height:auto!important;min-height:80px!important;padding:10px 8px!important}}.fingerprint-list-page .modal-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.5);display:flex;justify-content:center;align-items:center;z-index:1002;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.fingerprint-list-page .employee-info-modal-new{background:white;width:90vw;max-width:800px;max-height:90vh;border-radius:16px;box-shadow:0 20px 60px #00000040;display:flex;flex-direction:column;overflow:hidden;animation:modalSlideIn .3s ease-out}@keyframes modalSlideIn{0%{transform:scale(.95) translateY(-20px);opacity:0}to{transform:scale(1) translateY(0);opacity:1}}.fingerprint-list-page .modal-header-fixed{padding:20px 24px;border-bottom:1px solid #e5e7eb;display:flex;justify-content:space-between;align-items:center;flex-shrink:0;background:#f8fafc;border-radius:16px 16px 0 0}.fingerprint-list-page .modal-header-fixed h3{margin:0;font-size:20px;font-weight:600;color:#1f2937}.fingerprint-list-page .modal-close-btn{background:none;border:none;font-size:24px;color:#6b7280;cursor:pointer;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:8px;transition:all .2s}.fingerprint-list-page .modal-close-btn:hover{background:#f3f4f6;color:#374151}.fingerprint-list-page .modal-container-scrollable{flex:1;overflow-y:auto;padding:24px;scrollbar-width:thin;scrollbar-color:#d1d5db #f9fafb}.fingerprint-list-page .modal-container-scrollable::-webkit-scrollbar{width:8px}.fingerprint-list-page .modal-container-scrollable::-webkit-scrollbar-track{background:#f9fafb}.fingerprint-list-page .modal-container-scrollable::-webkit-scrollbar-thumb{background:#d1d5db;border-radius:4px}.fingerprint-list-page .modal-container-scrollable::-webkit-scrollbar-thumb:hover{background:#9ca3af}.fingerprint-list-page .info-frame-1{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-bottom:20px}.fingerprint-list-page .desktop-layout{display:flex;gap:24px;align-items:flex-start}.fingerprint-list-page .mobile-layout{display:none}.fingerprint-list-page .avatar-col{flex:0 0 120px;display:flex;justify-content:center}.fingerprint-list-page .avatar-container{position:relative;display:flex;flex-direction:column;align-items:center}.fingerprint-list-page .large-avatar{width:120px;height:120px;border-radius:12px;-o-object-fit:cover;object-fit:cover;border:3px solid #e5e7eb;cursor:pointer;transition:all .3s ease;box-shadow:0 4px 12px #0000001a}.fingerprint-list-page .large-avatar:hover{border-color:#3b82f6;transform:scale(1.02);box-shadow:0 8px 20px #3b82f633}.fingerprint-list-page .no-large-avatar{width:120px;height:120px;border:2px dashed #d1d5db;border-radius:12px;display:flex;align-items:center;justify-content:center;font-size:12px;color:#6b7280;background:#f9fafb;text-align:center;padding:8px}.fingerprint-list-page .basic-info-col{flex:1;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center;flex-wrap:wrap;gap:12px}.fingerprint-list-page .name-text{font-size:24px;font-weight:700;color:#1f2937}.fingerprint-list-page .employee-code{font-size:16px;font-weight:500;color:#6b7280}.fingerprint-list-page .status-container{display:flex;align-items:center}.fingerprint-list-page .status-badge{padding:6px 12px;border-radius:20px;font-size:14px;font-weight:500;display:inline-block}.fingerprint-list-page .status-pending{background:#fef3c7;color:#92400e;border:1px solid #f59e0b}.fingerprint-list-page .status-approved{background:#d1fae5;color:#065f46;border:1px solid #10b981}.fingerprint-list-page .status-rejected{background:#fee2e2;color:#991b1b;border:1px solid #ef4444}.fingerprint-list-page .fingerprint-time{font-size:14px;color:#6b7280}.fingerprint-list-page .info-frame-2{background:white;border:1px solid #e5e7eb;border-radius:12px;padding:20px}.fingerprint-list-page .detail-row{display:flex;gap:20px;margin-bottom:16px;flex-wrap:wrap}.fingerprint-list-page .detail-group{flex:1;min-width:200px;display:flex;flex-direction:column;gap:4px}.fingerprint-list-page .detail-group.full-width{flex:1 1 100%}.fingerprint-list-page .detail-group label{font-size:14px;font-weight:600;color:#374151}.fingerprint-list-page .detail-group span{font-size:15px;color:#1f2937;word-break:break-word}.fingerprint-list-page .modal-footer-fixed{padding:20px 24px;border-top:1px solid #e5e7eb;display:flex;justify-content:flex-end;gap:12px;flex-shrink:0;background:#f8fafc;border-radius:0 0 16px 16px}.fingerprint-list-page .update-btn{background:#3b82f6;color:#fff;border:none;padding:10px 20px;border-radius:8px;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s}.fingerprint-list-page .update-btn:hover{background:#2563eb;transform:translateY(-1px);box-shadow:0 4px 8px #3b82f64d}.fingerprint-list-page .fullscreen-image-overlay{position:fixed;top:0;left:0;width:100vw;height:100vh;background:rgba(0,0,0,.9);display:flex;justify-content:center;align-items:center;z-index:2000}.fingerprint-list-page .fullscreen-image-container{position:relative;max-width:95vw;max-height:95vh}.fingerprint-list-page .fullscreen-image{width:100%;height:100%;-o-object-fit:contain;object-fit:contain;border-radius:8px}.fingerprint-list-page .fullscreen-close-btn{position:absolute;top:-40px;right:0;background:white;color:#1f2937;border:none;width:40px;height:40px;border-radius:50%;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 4px 12px #0000004d}.fingerprint-list-page .info-frame-cccd{background:#f8fafc;border:1px solid #e5e7eb;border-radius:12px;padding:20px;margin-bottom:20px}.fingerprint-list-page .cccd-images-row{display:flex;gap:20px;justify-content:space-between}.fingerprint-list-page .cccd-image-item{flex:1;display:flex;flex-direction:column;gap:8px}.fingerprint-list-page .cccd-image-item label{font-size:14px;font-weight:600;color:#374151}.fingerprint-list-page .cccd-image-container{position:relative;width:100%;height:200px;border:2px solid #e5e7eb;border-radius:8px;overflow:hidden;background:#f9fafb;cursor:pointer;transition:all .3s ease}.fingerprint-list-page .cccd-image-container:hover{border-color:#3b82f6;transform:translateY(-2px);box-shadow:0 8px 20px #0000001a}.fingerprint-list-page .cccd-image-container img{width:100%;height:100%;-o-object-fit:cover;object-fit:cover}.fingerprint-list-page .no-cccd-image{width:100%;height:100%;display:flex;align-items:center;justify-content:center;text-align:center;color:#6b7280;font-size:14px;padding:16px}.fingerprint-list-page .basic-info-col .info-line{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e5e7eb}.fingerprint-list-page .basic-info-col .info-line:last-child{border-bottom:none}.fingerprint-list-page .basic-info-col .info-line .info-label{font-size:14px;font-weight:600;color:#374151;flex:0 0 120px}.fingerprint-list-page .basic-info-col .info-line .info-value{font-size:14px;color:#1f2937;flex:1;word-break:break-word}@media (max-width: 1024px){.fingerprint-list-page .employee-info-modal-new{width:95vw;max-height:95vh;border-radius:12px}.fingerprint-list-page .desktop-layout{display:none}.fingerprint-list-page .mobile-layout{display:block}.fingerprint-list-page .mobile-layout .mobile-row-2{text-align:center;margin-bottom:16px}.fingerprint-list-page .mobile-layout .mobile-row-3.text-center,.fingerprint-list-page .mobile-layout .mobile-row-4.text-center{text-align:center;margin-bottom:12px}.fingerprint-list-page .mobile-layout .mobile-row-5{text-align:right;margin-top:8px}.fingerprint-list-page .mobile-layout .large-avatar{width:100px;height:100px}.fingerprint-list-page .mobile-layout .no-large-avatar{width:100px;height:100px;font-size:11px}.fingerprint-list-page .cccd-images-row{flex-direction:column;gap:16px}.fingerprint-list-page .cccd-image-container{height:150px}.fingerprint-list-page .detail-row{flex-direction:column;gap:12px}.fingerprint-list-page .detail-group{min-width:unset}.fingerprint-list-page .modal-header-fixed{padding:16px 20px}.fingerprint-list-page .modal-header-fixed h3{font-size:18px}.fingerprint-list-page .modal-container-scrollable{padding:20px}.fingerprint-list-page .modal-footer-fixed{padding:16px 20px}}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html{height:100%;scroll-behavior:smooth}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;line-height:1.6;color:#333;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);min-height:100vh;overflow-x:hidden}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.4;margin-bottom:.5rem}h1{font-size:2.5rem}h2{font-size:2rem}h3{font-size:1.75rem}h4{font-size:1.5rem}h5{font-size:1.25rem}h6{font-size:1rem}p{margin-bottom:1rem}.app-btn{display:inline-flex;align-items:center;justify-content:center;gap:.5rem;padding:.75rem 1.5rem;border:none;border-radius:8px;font-size:.95rem;font-weight:500;cursor:pointer;transition:all .3s ease;text-decoration:none;white-space:nowrap}.app-btn:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000026}.app-btn-primary{background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);color:#fff}.app-btn-primary:hover{background:linear-gradient(135deg,#5a6fd8 0%,#6a4190 100%)}.app-btn-secondary{background:rgba(255,255,255,.9);color:#667eea;border:1px solid rgba(102,126,234,.3)}.app-btn-secondary:hover{background:white;border-color:#667eea}.btn-success{background:linear-gradient(135deg,#28a745 0%,#20c997 100%);color:#fff}.btn-success:hover{background:linear-gradient(135deg,#218838 0%,#1c9c7a 100%)}.btn-danger{background:linear-gradient(135deg,#dc3545 0%,#e83e8c 100%);color:#fff}.btn-danger:hover{background:linear-gradient(135deg,#c82333 0%,#d91a72 100%)}.btn-warning{background:linear-gradient(135deg,#ffc107 0%,#fd7e14 100%);color:#212529}.btn-warning:hover{background:linear-gradient(135deg,#e0a800 0%,#e8690b 100%)}.form-group{margin-bottom:1.5rem}.form-label{display:block;margin-bottom:.5rem;font-weight:500;color:#374151}.form-control{width:100%;padding:.75rem 1rem;font-size:1rem;line-height:1.5;color:#495057;background:rgba(255,255,255,.9);border:1px solid #ced4da;border-radius:8px;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.form-control:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;background:rgba(255,255,255,.95)}.form-control::-moz-placeholder{color:#6c757d}.form-control::placeholder{color:#6c757d}.app-card{background:rgba(255,255,255,.95);border-radius:12px;padding:1.5rem;box-shadow:0 8px 32px #0000001a;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);transition:all .3s ease}.app-card:hover{transform:translateY(-4px);box-shadow:0 12px 48px #00000026}.card-header{margin-bottom:1rem;padding-bottom:1rem;border-bottom:1px solid rgba(0,0,0,.1)}.card-title{font-size:1.25rem;font-weight:600;margin:0}.card-body{padding:0}.card-footer{margin-top:1rem;padding-top:1rem;border-top:1px solid rgba(0,0,0,.1)}.text-center{text-align:center}.text-left{text-align:left}.text-right{text-align:right}.d-flex{display:flex}.d-inline-flex{display:inline-flex}.d-block{display:block}.d-inline{display:inline}.d-none{display:none}.align-items-center{align-items:center}.align-items-start{align-items:flex-start}.align-items-end{align-items:flex-end}.justify-content-center{justify-content:center}.justify-content-between{justify-content:space-between}.justify-content-start{justify-content:flex-start}.justify-content-end{justify-content:flex-end}.gap-1{gap:.25rem}.gap-2{gap:.5rem}.gap-3{gap:1rem}.gap-4{gap:1.5rem}.m-0{margin:0}.m-1{margin:.25rem}.m-2{margin:.5rem}.m-3{margin:1rem}.m-4{margin:1.5rem}.p-0{padding:0}.p-1{padding:.25rem}.p-2{padding:.5rem}.p-3{padding:1rem}.p-4{padding:1.5rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideDown{0%{transform:translateY(-10px);opacity:0}to{transform:translateY(0);opacity:1}}.fade-in{animation:fadeIn .3s ease}.slide-down{animation:slideDown .3s ease}@media (max-width: 768px){body{font-size:14px}h1{font-size:2rem}h2{font-size:1.75rem}h3{font-size:1.5rem}h4{font-size:1.25rem}.btn{padding:.6rem 1.2rem;font-size:.9rem}.card{padding:1rem}}.main-layout{display:flex;min-height:100vh;background:#ffffff}.sidebar{position:fixed;left:0;top:50px;bottom:0;width:50px;background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-right:1px solid rgba(255,255,255,.2);box-shadow:2px 0 20px #0000001a;transition:all .3s ease;z-index:1001;display:flex;flex-direction:column}.sidebar.expanded{width:250px;z-index:1002}.sidebar.open{width:250px}.sidebar-toggle{background:none;border:none;color:#667eea;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .3s ease;display:flex;align-items:center;justify-content:center;position:absolute;left:5px;width:40px;height:40px}.sidebar-toggle:hover{background:rgba(102,126,234,.1)}.sidebar-nav{flex:1;display:flex;flex-direction:column;gap:.5rem;padding-top:1rem}.nav-item{position:relative;display:flex;align-items:center;padding:.75rem 1rem .75rem 0;color:#374151;text-decoration:none;margin:0;border-radius:8px;transition:background-color .3s ease,color .3s ease;cursor:pointer;overflow:hidden;min-height:48px}.nav-item:hover{background:rgba(102,126,234,.1);color:#667eea}.nav-item.active{background:#667eea;color:#fff}.nav-icon{flex-shrink:0;width:20px;height:20px;position:absolute;left:15px;transition:none}.nav-text{font-weight:500;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:left center;margin-left:40px}.nav-text.visible{opacity:1;transform:translate(0) scaleX(1);width:auto}.nav-text.hidden{opacity:0;transform:translate(-20px) scaleX(0);width:0;overflow:hidden}.nav-tooltip{position:absolute;left:50px;top:50%;transform:translateY(-50%);background:#333;color:#fff;padding:.5rem .75rem;border-radius:6px;font-size:.875rem;white-space:nowrap;z-index:1001;opacity:0;visibility:hidden;transition:all .3s ease;pointer-events:none}.nav-item:hover .nav-tooltip{opacity:1;visibility:visible}.active-indicator{position:absolute;left:-.5rem;top:50%;transform:translateY(-50%);width:3px;height:20px;background:white;border-radius:2px;opacity:0;transition:all .3s ease}.nav-item.active .active-indicator{opacity:1}.user-section{border-top:1px solid rgba(0,0,0,.1);padding:1rem 1rem 1rem 0}.logout-btn{background:none;border:none;color:#dc3545;cursor:pointer;padding:.75rem 1rem .75rem 0;border-radius:6px;transition:background-color .3s ease;display:flex;align-items:center;width:100%;position:relative;min-height:48px;overflow:hidden}.logout-btn:hover{background:rgba(220,53,69,.1)}.logout-icon{flex-shrink:0;width:16px;height:16px;position:absolute;left:15px;transition:none}.logout-text{font-weight:500;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:left center;margin-left:40px}.logout-text.visible{opacity:1;transform:translate(0) scaleX(1);width:auto}.logout-text.hidden{opacity:0;transform:translate(-20px) scaleX(0);width:0;overflow:hidden}.main-content{flex:1;min-height:100vh;display:flex;flex-direction:column;background:transparent}.main-header{background:rgba(255,255,255,.95);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:0;height:50px;box-shadow:0 2px 20px #0000001a;border-bottom:1px solid rgba(255,255,255,.2);position:sticky;top:0;z-index:1000;width:100%}.header-content{margin:0 auto;padding:0 5px;height:50px;display:flex;align-items:center;justify-content:space-between}.header-left{display:flex;align-items:center;gap:1rem;flex:1;min-width:0;overflow:hidden}.header-logo{height:65px;width:auto;-o-object-fit:contain;object-fit:contain;flex-shrink:0}.header-menu-toggle{background:none;border:none;color:#667eea;cursor:pointer;padding:.5rem;border-radius:6px;transition:all .3s ease;display:flex;align-items:center;justify-content:center;width:40px;height:40px;flex-shrink:0}.header-menu-toggle:hover{background:rgba(102,126,234,.1)}.page-title{font-size:1.5rem;font-weight:600;color:#2c3e50;margin:0}.header-right{display:flex;align-items:center;gap:1rem}.header-actions{display:flex;align-items:center;gap:.5rem}.header-title{font-size:1.25rem;font-weight:600;color:#2c3e50;margin:0}.user-greeting{color:#6c757d;font-size:.875rem;font-weight:500;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.user-avatar-header{width:32px;height:32px;border-radius:50%;background:#667eea;color:#fff;font-weight:600;font-size:.875rem;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .3s ease}.user-avatar-header:hover{background:#5a67d8;transform:scale(1.05)}.mobile-avatar{display:none;width:32px;height:32px;border-radius:50%;background:#667eea;color:#fff;font-weight:600;font-size:.875rem;align-items:center;justify-content:center}.app-container{margin:0 auto;width:100%;box-sizing:border-box}.nha-thoi-vu-filter-mobile-btn,.mobile-overlay{display:none}.content-area{flex:1;background:transparent;padding-left:50px;transition:padding-left .3s ease}@media (max-width: 768px){.sidebar{transform:translate(-100%);width:280px;top:50px}.sidebar.open{transform:translate(0)}.content-area{padding-left:0!important}.header-menu-toggle{display:flex}.mobile-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.5);z-index:999;display:block}.header-content{padding:0 .75rem;justify-content:space-between;width:100%}.header-left{gap:.4rem;flex:1;min-width:0;width:100%}.header-logo{height:45px}.nav-tooltip{display:none}.header-title{font-size:calc(12px + 2vw);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1;min-width:0;font-weight:600;max-font-size:18px}@media (max-width: 768px){.header-title{font-size:clamp(12px,calc(8px + 3vw),20px)}}@media (max-width: 480px){.header-title{font-size:clamp(11px,calc(6px + 4vw),18px)}}@media (max-width: 360px){.header-title{font-size:clamp(10px,calc(4px + 5vw),16px)}}@media (min-width: 769px){.header-title{font-size:1.25rem}}@supports (container-type: inline-size){.header-left{container-type:inline-size}@container (max-width: 400px){.header-title{font-size:clamp(10px,4cqw,16px)}}@container (max-width: 300px){.header-title{font-size:clamp(9px,5cqw,14px)}}}.header-title{text-overflow:ellipsis;overflow:hidden;white-space:nowrap;max-width:100%;flex:1;min-width:0}.header-menu-toggle{flex-shrink:0;width:40px;height:40px}.header-logo{flex-shrink:0}.user-greeting,.user-avatar-header,.mobile-avatar{display:none}.user-info-mobile{display:flex}.app-container{width:100vw;max-width:100vw;margin:0;box-sizing:border-box}.dktv-header{display:flex;flex-direction:row;align-items:center;gap:8px;padding:8px 0;box-shadow:none;border-radius:0}.dktv-header h2{display:none}.dktv-controls{display:flex;flex-direction:row;align-items:center;gap:8px;width:100%;padding:0;justify-content:space-between}.add-candidate-btn{min-width:40px;max-width:40px;height:40px;padding:0;justify-content:center;background:#28a745;border-radius:6px;color:#fff;font-size:0;display:flex;align-items:center;gap:0}.add-candidate-btn>svg{width:24px;height:24px;color:#fff}.search-container{flex:1;min-width:0;margin:0;max-width:calc(100% - 100px)}.search-input{font-size:14px;padding:8px 8px 8px 36px;border-radius:6px;width:100%}.nha-thoi-vu-filter{display:none!important}.nha-thoi-vu-filter-mobile-btn{display:flex;min-width:40px;max-width:40px;height:40px;background:#fff;border:1px solid #ddd;border-radius:6px;align-items:center;justify-content:center;cursor:pointer;margin-left:0;color:#667eea;transition:all .3s ease}.nha-thoi-vu-filter-mobile-btn:hover{background:rgba(102,126,234,.1);border-color:#667eea}.nha-thoi-vu-filter-mobile-btn>svg{width:22px;height:22px;color:#667eea}.nha-thoi-vu-modal-mobile{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.3);z-index:2000;display:flex;align-items:center;justify-content:center}.nha-thoi-vu-modal-content-mobile{background:#fff;border-radius:10px;box-shadow:0 2px 12px #00000026;padding:16px;min-width:220px;max-width:90vw;max-height:80vh;overflow-y:auto;position:relative}.nha-thoi-vu-modal-content-mobile h4{font-size:1.1rem;margin-bottom:12px;color:#2c3e50}.nha-thoi-vu-modal-list-mobile{list-style:none;padding:0;margin:0}.nha-thoi-vu-modal-list-mobile li{padding:10px 0;border-bottom:1px solid #eee;cursor:pointer;color:#374151;font-size:1rem;transition:background .2s}.nha-thoi-vu-modal-list-mobile li:last-child{border-bottom:none}.nha-thoi-vu-modal-list-mobile li:hover,.nha-thoi-vu-modal-list-mobile li.selected{background:#f0f4ff;color:#667eea}.nha-thoi-vu-modal-close-mobile{position:absolute;top:10px;right:16px;background:none;border:none;font-size:1.5rem;color:#667eea;cursor:pointer}}.user-info-mobile{display:none;align-items:center;padding:.75rem 1rem;margin-bottom:.5rem;border-bottom:1px solid rgba(0,0,0,.1);gap:.75rem}@media (min-width: 769px){.user-greeting{display:block!important}.user-avatar-header{display:flex!important}.mobile-avatar,.user-info-mobile{display:none!important}}.user-avatar-sidebar{width:32px;height:32px;border-radius:50%;background:#667eea;color:#fff;font-weight:600;font-size:.875rem;display:flex;align-items:center;justify-content:center;flex-shrink:0}.user-greeting-sidebar{color:#374151;font-size:.875rem;font-weight:500;white-space:nowrap;transition:all .3s cubic-bezier(.4,0,.2,1);transform-origin:left center;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica Neue,Arial,sans-serif,"Apple Color Emoji","Segoe UI Emoji",Segoe UI Symbol;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.user-greeting-sidebar.visible{opacity:1;transform:translate(0) scaleX(1);width:auto}.user-greeting-sidebar.hidden{opacity:0;transform:translate(-20px) scaleX(0);width:0;overflow:hidden}.sidebar-nav:has(.nav-item:only-child){justify-content:flex-start}@media (max-width: 768px){.sidebar.vendor-mode{background:rgba(102,126,234,.98)}.sidebar.vendor-mode .nav-item{color:#fff;font-weight:500}.sidebar.vendor-mode .nav-item:hover{background:rgba(255,255,255,.2)}.sidebar.vendor-mode .nav-item.active{background:rgba(255,255,255,.3)}.user-info-mobile{display:flex}.sidebar.vendor-mode .user-info-mobile{background:rgba(255,255,255,.1);border-bottom:1px solid rgba(255,255,255,.2)}.sidebar.vendor-mode .user-avatar-sidebar{background:rgba(255,255,255,.9);color:#667eea}.sidebar.vendor-mode .user-greeting-sidebar{color:#fff}}.auth-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(0,0,0,.6);display:flex;align-items:center;justify-content:center;z-index:9999;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.auth-modal{background:rgba(255,255,255,.95);border-radius:12px;padding:2rem;max-width:400px;width:90%;box-shadow:0 12px 48px #0003;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);animation:fadeIn .3s ease}.auth-modal-header{text-align:center;margin-bottom:1.5rem}.auth-modal-title{color:#2c3e50;font-size:1.5rem;font-weight:600;margin-bottom:.5rem}.auth-modal-subtitle{color:#6c757d;font-size:.95rem}.auth-modal-body{margin-bottom:1.5rem}.auth-modal-footer{display:flex;gap:1rem;justify-content:flex-end}.protected-loading{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%)}.protected-loading-spinner{width:64px;height:64px;border:4px solid rgba(255,255,255,.3);border-top:4px solid white;border-radius:50%;animation:spin 1s linear infinite}.protected-unauthorized{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:2rem}.protected-unauthorized-content{text-align:center;background:rgba(255,255,255,.95);padding:3rem;border-radius:12px;box-shadow:0 8px 32px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);max-width:500px;width:100%}.protected-unauthorized-title{font-size:2rem;font-weight:700;color:#dc3545;margin-bottom:.5rem}.protected-unauthorized-message{color:#6c757d;margin:1rem 0 2rem;line-height:1.6}.not-found-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:linear-gradient(135deg,#667eea 0%,#764ba2 100%);padding:2rem}.not-found-content{text-align:center;background:rgba(255,255,255,.95);padding:3rem;border-radius:12px;box-shadow:0 8px 32px #00000026;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid rgba(255,255,255,.2);max-width:500px;width:100%}.not-found-icon{width:64px;height:64px;color:#ffc107;margin-bottom:1rem}.not-found-title{font-size:4rem;font-weight:800;color:#dc3545;margin-bottom:.5rem;line-height:1}.not-found-subtitle{font-size:1.5rem;font-weight:600;color:#2c3e50;margin-bottom:1rem}.not-found-message{color:#6c757d;margin-bottom:2rem;line-height:1.6}.not-found-actions{display:flex;gap:1rem;justify-content:center;flex-wrap:wrap}.loading-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:rgba(255,255,255,.9);display:flex;align-items:center;justify-content:center;z-index:9998;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.loading-content{text-align:center;color:#667eea}.loading-content .loading-spinner{margin-bottom:1rem}.loading-text{font-size:1.1rem;font-weight:500}.toast-container{position:fixed;top:2rem;right:2rem;z-index:10000;display:flex;flex-direction:column;gap:.5rem}.toast{background:white;border-radius:8px;padding:1rem 1.5rem;box-shadow:0 4px 12px #00000026;border-left:4px solid #667eea;min-width:300px;animation:slideDown .3s ease;display:flex;align-items:center;gap:1rem}.toast.success{border-left-color:#28a745}.toast.error{border-left-color:#dc3545}.toast.warning{border-left-color:#ffc107}.toast.info{border-left-color:#17a2b8}.toast-icon{width:20px;height:20px;flex-shrink:0}.toast-content{flex:1}.toast-title{font-weight:600;margin-bottom:.25rem;font-size:.95rem}.toast-message{font-size:.875rem;color:#6c757d;line-height:1.4}.toast-close{background:none;border:none;color:#6c757d;cursor:pointer;padding:.25rem;border-radius:4px;transition:all .2s ease}.toast-close:hover{background:rgba(0,0,0,.1)}.dropdown{position:relative;display:inline-block}.dropdown-toggle{background:white;border:1px solid #dee2e6;border-radius:6px;padding:.5rem 1rem;cursor:pointer;display:flex;align-items:center;gap:.5rem;transition:all .2s ease}.dropdown-toggle:hover{border-color:#667eea}.dropdown-menu{position:absolute;top:100%;left:0;background:white;border:1px solid #dee2e6;border-radius:6px;box-shadow:0 4px 12px #00000026;z-index:1000;min-width:150px;padding:.5rem 0;display:none}.dropdown-menu.show{display:block;animation:slideDown .2s ease}.dropdown-item{display:block;padding:.5rem 1rem;color:#495057;text-decoration:none;border:none;background:none;width:100%;text-align:left;cursor:pointer;transition:all .2s ease}.dropdown-item:hover{background:#f8f9fa;color:#667eea}.dropdown-item.active{background:#667eea;color:#fff}@media (max-width: 768px){.auth-modal{margin:1rem;padding:1.5rem}.not-found-content,.protected-unauthorized-content{margin:1rem;padding:2rem}.not-found-title{font-size:3rem}.toast-container{top:1rem;right:1rem;left:1rem}.toast{min-width:auto;width:100%}.not-found-actions{flex-direction:column}}
