body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;margin:0}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}.qr-scanner-wrapper{display:flex;flex-direction:column;gap:16px;width:100%}.scanner-error{align-items:center;background-color:#ffebee;border:2px solid #e74c3c;border-radius:8px;display:flex;flex-direction:column;padding:16px;text-align:center}.scanner-error .error-icon{font-size:32px;margin:0 0 8px}.scanner-error .error-message{color:#c62828;font-size:14px;line-height:1.5;margin:0}.location-warning{align-items:center;background-color:#fff3e0;border:2px solid #ff9800;border-radius:8px;display:flex;gap:12px;padding:12px}.location-warning .warning-icon{flex-shrink:0;font-size:20px;margin:0}.location-warning .warning-message{color:#e65100;font-size:13px;line-height:1.4;margin:0}.scanner-container{aspect-ratio:1;background-color:#000;border:3px solid #2196f3;border-radius:12px;margin:0 auto;max-width:500px;overflow:hidden;position:relative;width:100%}#qr-reader{height:100%;width:100%}#qr-reader video{display:block;height:100%!important;object-fit:cover;width:100%!important}.scanner-video{height:100%;object-fit:cover;width:100%}.scanner-initializing{align-items:center;background-color:#000000b3;bottom:0;color:#fff;display:flex;flex-direction:column;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:10}.spinner{animation:spin 1s linear infinite;border:4px solid #ffffff4d;border-radius:50%;border-top-color:#2196f3;height:40px;margin-bottom:12px;width:40px}.scanner-initializing p{font-size:14px;margin:0}.scan-instruction{color:#666;font-size:13px;margin:8px 0 0;text-align:center}.location-info{background-color:#e3f2fd;border:1px solid #2196f3;border-radius:6px;padding:12px;text-align:center}.location-status{color:#1565c0;font-family:Courier New,monospace;font-size:13px;margin:0;word-break:break-all}@media (max-width:768px){.scanner-container{max-width:100%}}@media (max-width:480px){.scanner-container{border-width:2px}.location-status{font-size:12px}}.action-selection-panel{background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000001a;padding:20px 16px;text-align:center}.scanned-qr-info{margin-bottom:20px}.qr-code-preview{background:#f5f5f5;border-radius:6px;color:#999;font-family:monospace;font-size:11px;margin:0 0 12px;padding:8px 12px;text-align:left;word-break:break-all}.selection-prompt{color:#3c3c3c;font-size:14px;font-weight:600;margin:0}.action-buttons{grid-gap:10px;display:grid;gap:10px;grid-template-columns:1fr 1fr;margin:16px 0 12px}.action-btn{align-items:center;border:none;border-radius:10px;color:#fff;cursor:pointer;display:flex;flex-direction:column;font-size:14px;font-weight:600;gap:6px;justify-content:center;padding:16px 12px;transition:opacity .2s}.check-in-btn{background-color:#0070e1}.check-in-btn:hover:not(:disabled){background-color:#005fc3}.check-out-btn{background-color:#0070e1}.check-out-btn:hover:not(:disabled){background-color:#005fc3}.action-btn:disabled{cursor:not-allowed;opacity:.4}.btn-label{font-size:16px;font-weight:700}.btn-desc{font-size:12px;opacity:.85}.cancel-btn{background:#f8f8f8;border:1px solid #d0d0d0;border-radius:8px;color:#555;cursor:pointer;font-size:13px;margin-top:4px;padding:10px;transition:background-color .2s;width:100%}.cancel-btn:hover:not(:disabled){background-color:#efefef}.cancel-btn:disabled{cursor:not-allowed;opacity:.4}.processing-panel{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000001a;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:40px 20px}.processing-panel .spinner{animation:spin 1s linear infinite;border:3px solid #e0f7f4;border-radius:50%;border-top-color:#13c3a8;height:44px;margin-bottom:16px;width:44px}@keyframes spin{to{transform:rotate(1turn)}}.processing-panel p{color:#3c3c3c;font-size:15px;font-weight:500;margin:0}.complete-panel{align-items:center;background:#fff;border-radius:12px;box-shadow:0 1px 4px #0000001a;display:flex;flex-direction:column;justify-content:center;min-height:200px;padding:40px 20px}.success-checkmark{animation:bounce .5s ease;font-size:52px;margin-bottom:16px}@keyframes bounce{0%,to{transform:scale(1)}50%{transform:scale(1.15)}}.complete-panel p{color:#1a1a1a;font-size:15px;font-weight:600;margin:6px 0}.complete-message{color:#888;font-size:12px;font-weight:400;margin-top:8px!important}@media (max-width:480px){.action-buttons{grid-template-columns:1fr}.action-btn{padding:14px 12px}.scanned-qr-info{margin-bottom:16px}.action-selection-panel{padding:16px 12px}}.attendance-page{background-color:#f5f5f5;min-height:100vh}.attendance-container{margin:0 auto;max-width:900px}.attendance-container h1{color:#333;font-size:28px;margin-bottom:30px;text-align:center}.status-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:24px}.status-card h2{color:#333;font-size:18px;margin-bottom:16px}.status-info{display:flex;flex-direction:column;gap:12px}.status-time{color:#555;font-size:18px;margin:0}.worked-time{color:#2ecc71;font-size:24px;font-weight:700;margin:12px 0}.status-badge{border-radius:20px;display:inline-block;font-size:14px;font-weight:600;padding:8px 16px;width:fit-content}.status-badge.working{background-color:#e8f5e9;color:#2ecc71}.status-badge.not-working{background-color:#fff3e0;color:#ff9800}.gps-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:24px}.gps-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:16px}.gps-header h3{color:#333;font-size:18px;margin:0}.checkbox-label{align-items:center;cursor:pointer;display:flex;font-size:14px;gap:8px}.checkbox-label input{cursor:pointer;height:18px;width:18px}.gps-info{color:#666;font-family:Courier New,monospace;font-size:14px;margin:0}.gps-info.waiting{color:#ff9800;font-style:italic}.scanner-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;padding:24px}.scanner-card h3{color:#333;font-size:18px;margin-bottom:16px}.qr-result{background-color:#f0f0f0;border-radius:8px;padding:16px;text-align:center}.scanned-qr{color:#333;font-family:Courier New,monospace;font-size:12px;margin:0 0 12px;word-break:break-all}.btn-retry{background-color:#2196f3;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:14px;font-weight:600;padding:10px 20px}.btn-retry:hover:not(:disabled){background-color:#1976d2}.btn-retry:disabled{background-color:#ccc;cursor:not-allowed}.action-buttons{margin-bottom:20px}.btn{font-size:16px;min-width:150px;padding:14px 24px}.btn-check-in{background-color:#2ecc71;color:#fff}.btn-check-in:hover:not(:disabled){background-color:#27ae60;box-shadow:0 4px 12px #2ecc714d;transform:translateY(-2px)}.btn-check-out{background-color:#e74c3c;color:#fff}.btn-check-out:hover:not(:disabled){background-color:#c0392b;box-shadow:0 4px 12px #e74c3c4d;transform:translateY(-2px)}@media (max-width:768px){.attendance-container{padding:0 10px}.attendance-container h1{font-size:24px}.scanner-container{height:300px}.action-buttons{flex-direction:column}.btn{min-width:0;min-width:auto}.gps-header{align-items:flex-start;flex-direction:column;gap:12px}}.verification-status{background:linear-gradient(135deg,#f5f7fa,#c3cfe2);border-left:4px solid #667eea;border-radius:8px;margin-top:16px;padding:12px 16px}.verification-label{color:#666;font-size:13px;font-weight:600;margin:0 0 8px}.verification-badge{border-radius:16px;display:inline-block;font-size:13px;font-weight:600;margin:0;padding:6px 12px}.verification-badge.pending{background:linear-gradient(135deg,#fff3e0,#ffe0b2);border:1px solid #ffb74d;color:#e65100}.verification-badge.verified{background:linear-gradient(135deg,#e8f5e9,#c8e6c9);border:1px solid #81c784;color:#1b5e20}.verification-badge.rejected{background:linear-gradient(135deg,#ffebee,#ffcdd2);border:1px solid #ef5350;color:#b71c1c}.status-badge.completed{background-color:#e8f5e9;color:#2ecc71}.scanner-info{background:#f0f8ff;border-left:3px solid #2196f3;border-radius:6px;color:#666;font-size:14px;margin:0 0 16px;padding:12px}.info-card{background:#fff;border-left:4px solid #2196f3;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:20px;margin-top:20px;padding:20px}.info-card h3{color:#333;font-size:16px;margin:0 0 12px}.info-list{color:#666;font-size:14px;line-height:1.8;margin:0;padding-left:20px}.info-list li{margin-bottom:8px}.info-list ul{margin-bottom:0;margin-top:4px;padding-left:20px}.wallet-page{background-color:#f5f5f5;min-height:100vh;padding:0}.wallet-container{margin:0 auto;max-width:900px;padding:20px}.alert{align-items:center;border-radius:8px;display:flex;font-size:14px;gap:12px;margin-bottom:20px;padding:16px}.alert-error{background-color:#ffebee;border-left:4px solid #c62828;color:#c62828}.alert-success{background-color:#e8f5e9;border-left:4px solid #2ecc71;color:#2ecc71}.balance-card{background:linear-gradient(135deg,#667eea,#764ba2);border-radius:16px;box-shadow:0 8px 16px #00000026;color:#fff;margin-bottom:24px;padding:32px}.balance-card h2{font-size:18px;font-weight:500;margin:0 0 16px;opacity:.9}.balance-amount{font-size:48px;font-weight:700;line-height:1;margin-bottom:24px}.balance-info{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.info-item{align-items:center;background-color:#ffffff1a;border-radius:8px;display:flex;justify-content:space-between;padding:12px}.info-item .label{font-size:14px;opacity:.9}.info-item .value{font-size:18px;font-weight:600}.statistics-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;margin-bottom:24px;padding:24px}.statistics-card h2{color:#333;font-size:18px;margin-bottom:16px}.stats-grid{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-item{background-color:#f9f9f9;border-radius:8px;display:flex;flex-direction:column;gap:8px;padding:16px}.stat-item .label{color:#666;font-size:13px}.stat-item .value{color:#333;font-size:22px;font-weight:700}.stat-item .value.earned{color:#2ecc71}.stat-item .value.transferred{color:#3498db}.action-buttons{display:flex;flex-wrap:wrap;gap:12px;margin-bottom:24px}.btn{border:none;border-radius:8px;cursor:pointer;flex:1 1;font-size:14px;font-weight:600;min-width:120px;padding:12px 24px;transition:all .3s ease}.btn-withdrawal{background-color:#3498db;color:#fff}.btn-withdrawal:hover:not(:disabled){background-color:#2980b9;box-shadow:0 4px 12px #3498db4d;transform:translateY(-2px)}.btn-verify{background-color:#9b59b6;color:#fff}.btn-verify:hover:not(:disabled){background-color:#8e44ad;box-shadow:0 4px 12px #9b59b64d;transform:translateY(-2px)}.btn-refresh{background-color:#95a5a6;color:#fff}.btn-refresh:hover:not(:disabled){background-color:#7f8c8d;box-shadow:0 4px 12px #95a5a64d;transform:translateY(-2px)}.btn:disabled{background-color:#ccc;color:#999;cursor:not-allowed}.transactions-card{background:#fff;border-radius:12px;box-shadow:0 2px 8px #0000001a;padding:24px}.transactions-card+.transactions-card{margin-top:24px}.transactions-card h2{color:#333;font-size:18px;margin-bottom:16px}.transactions-list{display:flex;flex-direction:column;gap:12px;max-height:600px;overflow-y:auto}.transaction-item{background-color:#fafafa;border:1px solid #e0e0e0;border-radius:8px;padding:16px;transition:all .2s ease}.transaction-item:hover{background-color:#f5f5f5;box-shadow:0 2px 4px #0000000d}.transaction-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:12px}.type-badge{background-color:#e3f2fd;border-radius:12px;color:#1976d2;display:inline-block;font-size:12px;font-weight:600;padding:4px 12px}.date{color:#999;font-size:12px}.transaction-details{display:flex;flex-direction:column;gap:8px}.description{color:#555;font-size:14px;margin:0}.transaction-row{align-items:center;display:flex;font-size:13px;justify-content:space-between}.transaction-row .label{color:#999}.transaction-row .amount{color:#2ecc71;font-weight:600}.transaction-row .amount.debit{color:#e74c3c}.transaction-row .value{color:#333}.transaction-row .hash{color:#2196f3;font-family:Courier New,monospace;font-size:11px;word-break:break-all}.no-transactions{color:#999;margin:0;padding:24px;text-align:center}.btn-load-more{background-color:#f0f0f0;border:1px solid #e0e0e0;border-radius:8px;color:#666;cursor:pointer;font-weight:600;margin-top:16px;padding:12px;transition:all .2s ease;width:100%}.btn-load-more:hover{background-color:#e8e8e8}.modal-overlay{align-items:center;background-color:#00000080;bottom:0;display:flex;justify-content:center;left:0;padding:20px;position:fixed;right:0;top:0;z-index:1000}.modal-content{background:#fff;border-radius:12px;box-shadow:0 8px 32px #0003;max-width:500px;overflow:hidden;width:100%}.modal-content h2{color:#333;font-size:20px;margin:0;padding:24px 24px 0}.modal-body{border-bottom:1px solid #e0e0e0;padding:24px}.modal-body p{color:#666;font-size:14px;margin:0 0 16px}.balance-display{background-color:#f0f0f0;border-radius:6px;color:#333;font-size:16px;font-weight:600;padding:12px}.form-group{display:flex;flex-direction:column;gap:8px;margin-top:16px}.form-group label{color:#333;font-size:14px;font-weight:600}.form-group input{border:1px solid #ddd;border-radius:6px;font-family:Courier New,monospace;font-size:14px;padding:12px}.form-group input:focus{border-color:#3498db;box-shadow:0 0 0 3px #3498db1a;outline:none}.form-group input:disabled{background-color:#f0f0f0;cursor:not-allowed}.verification-result{border:2px solid;border-radius:8px;padding:16px}.verification-result.valid{background-color:#e8f5e9;border-color:#2ecc71}.verification-result.invalid{background-color:#ffebee;border-color:#e74c3c}.result-status{font-size:16px;font-weight:700;margin:0 0 12px}.verification-result.valid .result-status{color:#2ecc71}.verification-result.invalid .result-status{color:#e74c3c}.errors-list{margin-top:12px}.errors-list h4{color:#666;font-size:14px;margin:0 0 8px}.errors-list ul{color:#555;font-size:13px;margin:0;padding-left:20px}.errors-list li{margin-bottom:6px}.modal-footer{background-color:#f9f9f9;display:flex;gap:12px;justify-content:flex-end;padding:16px 24px}.btn-cancel,.btn-close,.btn-confirm{border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:600;padding:10px 24px;transition:all .2s ease}.btn-cancel,.btn-close{background-color:#e0e0e0;color:#333}.btn-cancel:hover:not(:disabled),.btn-close:hover{background-color:#d0d0d0}.btn-confirm{background-color:#3498db;color:#fff}.btn-confirm:hover:not(:disabled){background-color:#2980b9}.btn-cancel:disabled{cursor:not-allowed;opacity:.6}.loading{color:#666;padding:20px;text-align:center}@media (max-width:768px){.wallet-container{padding:0 10px}.wallet-container h1{font-size:24px}.balance-amount{font-size:36px}.balance-info{grid-template-columns:1fr}.action-buttons{flex-direction:column}.btn{min-width:0;min-width:auto}.stats-grid{grid-template-columns:1fr}.modal-content{max-width:90%}}
/*# sourceMappingURL=main.aaf38867.css.map*/