*,*:before,*:after{box-sizing:border-box;margin:0;padding:0;-webkit-tap-highlight-color:transparent}:root{--blue: #1d4ed8;--blue-dark: #1e3a8a;--blue-light: #dbeafe;--green: #16a34a;--green-light: #dcfce7;--red: #dc2626;--red-light: #fee2e2;--amber: #d97706;--bg: #f1f5f9;--surface: #ffffff;--border: #e2e8f0;--text: #0f172a;--muted: #64748b;--radius: 14px;--shadow: 0 1px 3px rgba(0,0,0,.1), 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 6px rgba(0,0,0,.07), 0 2px 4px rgba(0,0,0,.05);--shadow-lg: 0 10px 15px rgba(0,0,0,.1), 0 4px 6px rgba(0,0,0,.05)}[data-theme=dark]{--bg: #0f172a;--surface: #1e293b;--border: #334155;--text: #f1f5f9;--muted: #94a3b8;--blue-light: #1e3a8a;--green-light: #14532d;--red-light: #7f1d1d;--shadow: 0 1px 3px rgba(0,0,0,.4), 0 1px 2px rgba(0,0,0,.3);--shadow-md: 0 4px 6px rgba(0,0,0,.3), 0 2px 4px rgba(0,0,0,.2)}html,body,#root{height:100%}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text);font-size:15px;line-height:1.5;-webkit-font-smoothing:antialiased}.root-wrap{max-width:480px;margin:0 auto;min-height:100%;display:flex;flex-direction:column;background:var(--bg)}.screen{min-height:100vh;display:flex;flex-direction:column}.login-bg{background:linear-gradient(160deg,var(--blue-dark) 0%,var(--blue) 60%,#3b82f6 100%);color:#fff}.login-top{display:flex;flex-direction:column;align-items:center;padding:52px 24px 36px;gap:6px}.brand-badge{width:72px;height:72px;border-radius:20px;background:#ffffff2e;border:2px solid rgba(255,255,255,.3);display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:900;letter-spacing:-2px;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.brand-name{font-size:28px;font-weight:800;letter-spacing:4px}.brand-sub{font-size:13px;opacity:.75;text-align:center;max-width:240px}.user-select{flex:1;background:var(--bg);border-radius:24px 24px 0 0;padding:24px 16px 32px}.section-label{font-size:13px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.8px;margin-bottom:14px;padding:0 4px}.user-list{display:flex;flex-direction:column;gap:10px}.user-card{display:flex;align-items:center;gap:14px;background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);padding:14px 16px;cursor:pointer;transition:transform .12s,box-shadow .12s;text-align:left;box-shadow:var(--shadow)}.user-card:active{transform:scale(.98)}.user-text{flex:1;display:flex;flex-direction:column;gap:2px}.user-name{font-size:16px;font-weight:600;color:var(--text)}.user-role{font-size:13px;color:var(--muted)}.chevron{font-size:22px;color:#cbd5e1;font-weight:300}.avatar{border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;flex-shrink:0}.avatar{width:44px;height:44px;font-size:15px}.avatar.lg{width:72px;height:72px;font-size:24px}.avatar.sm{width:34px;height:34px;font-size:12px}.avatar.xs{width:28px;height:28px;font-size:10px}.pin-wrap{flex:1;background:var(--bg);border-radius:24px 24px 0 0;padding:20px 24px 32px;display:flex;flex-direction:column;align-items:center}.back-link{align-self:flex-start;background:none;border:none;color:var(--blue);font-size:14px;font-weight:600;cursor:pointer;padding:4px 0;margin-bottom:20px}.pin-user{display:flex;flex-direction:column;align-items:center;gap:6px;margin-bottom:28px}.pin-uname{font-size:18px;font-weight:700}.pin-urole{font-size:13px;color:var(--muted)}.pin-prompt{font-size:14px;color:var(--muted);margin-bottom:16px}.pin-dots{display:flex;gap:16px;margin-bottom:12px}.dot{width:16px;height:16px;border-radius:50%;border:2px solid #cbd5e1;background:transparent;transition:background .15s,border-color .15s}.dot.filled{background:var(--blue);border-color:var(--blue)}.dot.filled.dot-err{background:var(--red);border-color:var(--red)}.dot.dot-err{border-color:var(--red)}.pin-err{font-size:13px;color:var(--red);margin-bottom:10px}.pin-pad{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;width:100%;max-width:280px;margin-top:8px}.pin-btn{height:64px;border-radius:16px;border:1px solid var(--border);background:var(--surface);font-size:22px;font-weight:600;cursor:pointer;box-shadow:var(--shadow);transition:transform .1s,background .1s;color:var(--text)}.pin-btn:active{transform:scale(.94);background:var(--blue-light)}.pin-btn:disabled{background:transparent;box-shadow:none;border-color:transparent}.pin-del{font-size:18px}@keyframes shake{0%,to{transform:translate(0)}20%{transform:translate(-8px)}40%{transform:translate(8px)}60%{transform:translate(-6px)}80%{transform:translate(6px)}}.shake{animation:shake .4s ease-in-out}.app-bar{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--blue-dark);color:#fff;position:sticky;top:0;z-index:10}.appbar-brand{flex:1;font-size:18px;font-weight:800;letter-spacing:3px}.appbar-p{opacity:.7}.appbar-title{flex:1;font-size:17px;font-weight:700}.appbar-right{display:flex;align-items:center;gap:10px}.logout-btn{background:#ffffff26;border:none;border-radius:8px;color:#fff;font-size:15px;width:32px;height:32px;cursor:pointer;display:flex;align-items:center;justify-content:center}.logout-btn:active{background:#ffffff4d}.back-icon-btn{background:none;border:none;color:#fff;font-size:20px;cursor:pointer;padding:4px}.steps-bar{display:flex;align-items:center;padding:16px 24px;background:var(--surface);border-bottom:1px solid var(--border)}.step-item{display:flex;align-items:center;gap:8px;font-size:14px;font-weight:600;color:var(--muted);flex:1}.step-item.step-done{color:var(--green)}.step-item.step-active{color:var(--blue)}.step-circle{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;background:#e2e8f0;color:var(--muted);flex-shrink:0}.step-active .step-circle{background:var(--blue);color:#fff}.step-done .step-circle{background:var(--green);color:#fff}.step-line{flex:1;height:2px;background:#e2e8f0;margin:0 8px}.val-screen{background:var(--bg)}.val-body{flex:1;padding:16px;display:flex;flex-direction:column;gap:12px}.val-footer{padding:8px 12px 20px;display:flex;gap:6px;justify-content:center;flex-wrap:wrap}.footer-btn{background:var(--surface);border:1.5px solid var(--border);border-radius:10px;padding:8px 12px;font-size:12px;font-weight:600;color:var(--text);cursor:pointer;white-space:nowrap}.footer-btn:active{background:var(--border)}.btn-compare{background:var(--blue);color:#fff;border:none;border-radius:14px;padding:18px;font-size:17px;font-weight:800;cursor:pointer;width:100%;box-shadow:0 4px 12px #1d4ed859;transition:background .12s,transform .1s;letter-spacing:.3px}.btn-compare:active{background:#1e3a8a;transform:scale(.98)}.method-badge{font-size:12px;font-weight:600;border-radius:8px;padding:6px 10px;margin-bottom:4px}.method-ok{background:var(--green-light);color:var(--green)}.method-warn{background:#fef9c3;color:#92400e}.method-err{background:var(--red-light);color:var(--red)}.history-link{background:none;border:none;color:var(--muted);font-size:14px;cursor:pointer;text-decoration:underline;padding:8px}.ocr-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:48px 24px;flex:1}.ocr-spinner{width:48px;height:48px;border:4px solid var(--blue-light);border-top-color:var(--blue);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.ocr-text{font-size:16px;font-weight:600;color:var(--text)}.ocr-bar-wrap{width:200px;height:6px;background:var(--border);border-radius:3px;overflow:hidden}.ocr-bar{height:100%;background:var(--blue);border-radius:3px;transition:width .2s ease}.ocr-pct{font-size:13px;color:var(--muted)}.capture-section{display:flex;flex-direction:column;gap:12px}.capture-card{background:var(--surface);border-radius:var(--radius);border:1.5px solid var(--border);box-shadow:var(--shadow);overflow:hidden}.capture-done{border-color:var(--green)}.capture-locked{opacity:.55}.capture-card-header{display:flex;align-items:center;gap:10px;padding:14px 16px;border-bottom:1px solid var(--border)}.capture-num{width:26px;height:26px;background:var(--blue-light);color:var(--blue);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:13px;font-weight:700;flex-shrink:0}.capture-done .capture-num{background:var(--green-light);color:var(--green)}.capture-title{flex:1;font-weight:600;font-size:15px}.badge-ok{font-size:12px;font-weight:700;background:var(--green-light);color:var(--green);border-radius:99px;padding:2px 10px}.capture-btn-large{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;width:100%;padding:32px 16px;background:none;border:none;cursor:pointer;transition:background .12s}.capture-btn-large:hover{background:var(--blue-light)}.capture-btn-large:active{background:#bfdbfe}.capture-btn-large:disabled{opacity:.4;cursor:not-allowed}.capture-icon{font-size:36px}.capture-btn-large span:last-child{font-size:15px;font-weight:600;color:var(--blue)}.locked-msg{display:flex;align-items:center;gap:8px;padding:24px 16px;color:var(--muted);font-size:14px}.lock-icon{font-size:20px}.capture-preview{padding:14px 16px;display:flex;flex-direction:column;gap:12px}.thumb{width:100%;max-height:180px;object-fit:cover;border-radius:10px;border:1px solid var(--border)}.code-block{background:#f8fafc;border:1px solid var(--border);border-radius:10px;padding:10px 12px}.code-lbl{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);margin-bottom:4px}.code-display-row{display:flex;align-items:center;gap:8px}.code-empty{font-size:13px;color:#94a3b8;font-style:italic;flex:1}.code-display{font-family:Courier New,monospace;font-size:17px;font-weight:700;color:var(--text);word-break:break-all;flex:1}.edit-btn{background:none;border:none;color:var(--muted);font-size:16px;cursor:pointer;padding:4px;border-radius:6px}.edit-btn:hover{background:var(--border)}.code-input{width:100%;font-family:Courier New,monospace;font-size:17px;font-weight:700;border:2px solid var(--blue);border-radius:8px;padding:6px 10px;color:var(--text);outline:none}.btn-primary{display:block;width:100%;background:var(--blue);color:#fff;border:none;border-radius:12px;padding:14px;font-size:16px;font-weight:700;cursor:pointer;text-align:center;transition:background .12s}.btn-primary:hover{background:#1d40af}.btn-primary:active{background:#1e3a8a}.btn-outline{background:none;color:var(--blue);border:1.5px solid var(--blue);border-radius:10px;padding:10px 16px;font-size:14px;font-weight:600;cursor:pointer;transition:background .12s}.btn-outline:hover{background:var(--blue-light)}.btn-outline.sm{font-size:13px;padding:7px 12px}.btn-text-danger{background:none;border:none;color:var(--red);font-size:14px;cursor:pointer;padding:8px 16px;border-radius:8px}.btn-text-danger:hover{background:var(--red-light)}.btn-danger{background:var(--red);color:#fff;border:none;border-radius:10px;padding:10px 20px;font-size:14px;font-weight:700;cursor:pointer}.camera-screen{position:fixed;top:0;right:0;bottom:0;left:0;background:#000;display:flex;flex-direction:column;z-index:50}.camera-header{display:flex;align-items:center;gap:12px;padding:14px 16px;background:#0009;color:#fff}.cam-back{background:#ffffff26;border:none;border-radius:8px;color:#fff;font-size:18px;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer}.cam-label{font-size:15px;font-weight:600;color:#fff;flex:1}.video-wrap{flex:1;position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.video-preview{width:100%;height:100%;object-fit:cover}.scan-frame{position:absolute;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;pointer-events:none}.corner{position:absolute;width:28px;height:28px;border-color:#fff;border-style:solid;border-width:0;opacity:.9}.corner.tl{top:20%;left:10%;border-top-width:3px;border-left-width:3px;border-radius:4px 0 0}.corner.tr{top:20%;right:10%;border-top-width:3px;border-right-width:3px;border-radius:0 4px 0 0}.corner.bl{bottom:24%;left:10%;border-bottom-width:3px;border-left-width:3px;border-radius:0 0 0 4px}.corner.br{bottom:24%;right:10%;border-bottom-width:3px;border-right-width:3px;border-radius:0 0 4px}.scan-found .corner{border-color:#4ade80;animation:pulse-green .5s ease infinite alternate}@keyframes pulse-green{0%{opacity:.7}to{opacity:1}}.scan-hint{position:absolute;bottom:22%;left:50%;transform:translate(-50%);font-size:13px;color:#fffc;white-space:nowrap;background:#0006;padding:4px 12px;border-radius:99px}.scan-hint-ok{background:#4ade80d9!important;color:#14532d!important;font-weight:800;font-size:14px!important}.cam-footer{padding:20px 16px 36px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;background:#000000b3}.cam-tip{color:#ffffffb3;font-size:12px;text-align:center;margin:0}.cam-found-bar{display:flex;flex-direction:column;align-items:center;gap:6px;color:#fff}.cam-found-bar span{font-size:14px;opacity:.8}.cam-found-code{font-family:Courier New,monospace;font-size:22px;font-weight:900;color:#4ade80;letter-spacing:2px}.shutter-btn{width:72px;height:72px;border-radius:50%;background:#ffffffe6;border:4px solid white;cursor:pointer;display:flex;align-items:center;justify-content:center;box-shadow:0 0 0 4px #ffffff4d;transition:transform .12s}.shutter-btn:active{transform:scale(.92)}.shutter-btn:disabled{opacity:.4;cursor:not-allowed}.shutter-inner{width:54px;height:54px;border-radius:50%;background:#fff}.flash-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#fff;z-index:100;animation:flash .18s ease-out forwards;pointer-events:none}@keyframes flash{0%{opacity:.9}to{opacity:0}}.cam-error{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:32px;color:#fff;text-align:center}.cam-error-icon{font-size:48px}.file-mode-wrap{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:16px;padding:40px 32px;text-align:center}.file-mode-icon{font-size:64px}.file-mode-title{font-size:20px;font-weight:700;color:#fff}.file-mode-hint{font-size:14px;color:#ffffffbf;line-height:1.6;max-width:280px}.file-capture-btn{background:#fff;color:#1e3a8a;border:none;border-radius:16px;padding:18px 40px;font-size:18px;font-weight:800;cursor:pointer;box-shadow:0 4px 16px #00000040;transition:transform .1s}.file-capture-btn:active{transform:scale(.96)}.result-overlay{position:fixed;top:0;right:0;bottom:0;left:0;display:flex;align-items:center;justify-content:center;z-index:60;padding:24px;opacity:0;transition:opacity .25s ease}.result-enter{opacity:0}.result-visible{opacity:1}.result-ok{background:#16a34aeb}.result-fail{background:#dc2626eb}.result-card{background:#fff;border-radius:24px;padding:32px 24px;width:100%;max-width:380px;display:flex;flex-direction:column;align-items:center;gap:12px;box-shadow:var(--shadow-lg);animation:popIn .25s ease}@keyframes popIn{0%{transform:scale(.85)}to{transform:scale(1)}}.result-icon{width:72px;height:72px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:36px;font-weight:700;color:#fff}.result-ok .result-icon{background:var(--green)}.result-fail .result-icon{background:var(--red)}.result-title{font-size:26px;font-weight:900;letter-spacing:1px}.result-ok .result-title{color:var(--green)}.result-fail .result-title{color:var(--red)}.result-sub{font-size:14px;color:var(--muted);text-align:center;max-width:260px}.result-codes{width:100%;background:#f8fafc;border:1px solid var(--border);border-radius:12px;padding:12px 16px;margin:8px 0}.code-row{display:flex;align-items:center;gap:10px}.code-label{font-size:12px;font-weight:600;text-transform:uppercase;letter-spacing:.6px;color:var(--muted);width:60px;flex-shrink:0}.code-val{font-family:Courier New,monospace;font-size:15px;font-weight:700;color:var(--text);word-break:break-all}.code-divider{height:1px;background:var(--border);margin:8px 0}.result-actions{display:flex;flex-direction:column;gap:8px;width:100%}.btn-result-primary{background:var(--blue);color:#fff;border:none;border-radius:12px;padding:15px;font-size:16px;font-weight:700;cursor:pointer;text-align:center;transition:background .12s}.btn-result-primary:hover{background:#1d40af}.btn-result-secondary{background:none;color:var(--blue);border:1.5px solid var(--blue);border-radius:12px;padding:13px;font-size:15px;font-weight:600;cursor:pointer;text-align:center;transition:background .12s}.btn-result-secondary:hover{background:var(--blue-light)}.hist-screen{background:var(--bg)}.filter-tabs{display:flex;gap:0;background:var(--surface);border-bottom:1px solid var(--border);padding:0 8px}.filter-tab{flex:1;padding:12px 8px;background:none;border:none;border-bottom:3px solid transparent;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;display:flex;align-items:center;justify-content:center;gap:5px;transition:color .12s}.filter-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.filter-cnt{background:var(--border);border-radius:99px;padding:1px 7px;font-size:11px}.filter-tab.active .filter-cnt{background:var(--blue-light);color:var(--blue)}.hist-list{flex:1;overflow-y:auto;padding:12px 14px;display:flex;flex-direction:column;gap:8px}.hist-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:64px 24px;gap:12px;color:var(--muted)}.hist-empty-icon{font-size:40px}.hist-item{background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);overflow:hidden;box-shadow:var(--shadow)}.admin-screen{background:var(--bg);display:flex;flex-direction:column}.admin-header{display:flex;align-items:center;gap:12px;padding:14px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.admin-toolbar{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.admin-count{font-size:13px;color:var(--muted)}.btn-primary{background:var(--blue);color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}.btn-primary:active{opacity:.85}.btn-primary.sm{padding:7px 14px;font-size:13px}.btn-outline{background:transparent;color:var(--blue);border:1.5px solid var(--blue);border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}.btn-outline.sm{padding:6px 12px;font-size:12px}.btn-danger{background:#dc2626;color:#fff;border:none;border-radius:8px;padding:10px 18px;font-size:14px;font-weight:600;cursor:pointer}.btn-icon{background:transparent;border:none;font-size:18px;cursor:pointer;padding:6px;border-radius:6px}.btn-icon:active{background:var(--border)}.btn-icon.danger{color:#dc2626}.admin-loading{display:flex;justify-content:center;padding:40px}.admin-list{flex:1;overflow-y:auto;padding:12px 16px;display:flex;flex-direction:column;gap:8px}.admin-user-row{display:flex;align-items:center;gap:12px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:12px}.admin-user-row.inactive{opacity:.6}.admin-user-info{flex:1;display:flex;flex-direction:column;gap:2px}.admin-user-actions{display:flex;gap:4px}.admin-section-label{font-size:12px;color:var(--muted);font-weight:600;text-transform:uppercase;letter-spacing:.05em;padding:8px 0 4px}.admin-form-wrap{flex:1;overflow-y:auto;padding:16px}.admin-form-title{font-size:17px;font-weight:700;margin-bottom:20px}.admin-form{display:flex;flex-direction:column;gap:16px}.form-field{display:flex;flex-direction:column;gap:6px}.form-field label{font-size:13px;font-weight:600;color:var(--text)}.form-field input,.form-field select{border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:15px;background:var(--surface);color:var(--text);outline:none}.form-field input:focus,.form-field select:focus{border-color:var(--blue)}.notes-section{display:flex;flex-direction:column}.notes-input{border:1.5px solid var(--border);border-radius:10px;padding:10px 12px;font-size:14px;background:var(--surface);color:var(--text);resize:none;font-family:inherit;outline:none}.notes-input:focus{border-color:var(--blue)}.btn-notes-toggle{background:none;border:none;color:var(--muted);font-size:13px;cursor:pointer;padding:4px 0;text-align:left}.btn-manual-entry{background:none;border:none;color:var(--blue);font-size:13px;cursor:pointer;padding:6px 0;text-align:center;width:100%;font-weight:500}.hist-source-tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border)}.source-tab{flex:1;padding:10px;border:none;background:none;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent}.source-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.hist-notes{font-size:13px;color:var(--muted);padding:6px 0}.hist-notes-label{font-weight:600;color:var(--text)}.sync-badge{font-size:11px;color:var(--amber)}.shutter-row{display:flex;align-items:center;justify-content:center;gap:16px}.torch-btn{background:#ffffff26;border:none;border-radius:50%;width:44px;height:44px;font-size:20px;cursor:pointer;display:flex;align-items:center;justify-content:center}.torch-btn.torch-on{background:#ffdc0059}.dash-date-row{padding:10px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.dash-date-input{border:1.5px solid var(--border);border-radius:8px;padding:7px 10px;font-size:14px;background:var(--surface);color:var(--text);outline:none}.dash-tabs{display:flex;background:var(--surface);border-bottom:1px solid var(--border)}.dash-tab{flex:1;padding:10px;border:none;background:none;font-size:13px;font-weight:600;color:var(--muted);cursor:pointer;border-bottom:2px solid transparent}.dash-tab.active{color:var(--blue);border-bottom-color:var(--blue)}.dash-body{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:16px}.dash-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:10px}.dash-card{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:14px 10px;text-align:center;display:flex;flex-direction:column;gap:4px}.dash-card.ok{border-color:var(--green);background:var(--green-light)}.dash-card.fail{border-color:var(--red);background:var(--red-light)}.dash-num{font-size:28px;font-weight:800}.dash-lbl{font-size:11px;color:var(--muted);font-weight:600;text-transform:uppercase}.dash-pct-wrap{display:flex;align-items:center;gap:10px}.dash-pct-bar{flex:1;height:10px;background:var(--border);border-radius:99px;overflow:hidden}.dash-pct-fill{height:100%;background:var(--green);border-radius:99px;transition:width .4s}.dash-pct-label{font-size:13px;font-weight:700;color:var(--green);white-space:nowrap}.dash-section{background:var(--surface);border-radius:12px;border:1px solid var(--border);padding:14px}.dash-section-title{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.05em;color:var(--muted);margin-bottom:10px}.dash-user-row{display:flex;align-items:center;gap:8px;padding:5px 0}.dash-uname{width:110px;font-size:13px;font-weight:600;flex-shrink:0}.dash-ubar-wrap{flex:1;height:8px;background:var(--border);border-radius:99px;overflow:hidden}.dash-ubar{height:100%;background:var(--blue);border-radius:99px;min-width:4px}.dash-ucnt{font-size:12px;color:var(--muted);white-space:nowrap}.dash-hours{display:flex;align-items:flex-end;gap:4px;height:70px}.dash-hour-bar-wrap{display:flex;flex-direction:column;align-items:center;gap:3px;flex:1}.dash-hour-bar{width:100%;background:var(--blue);border-radius:4px 4px 0 0;min-height:4px}.dash-hour-label{font-size:9px;color:var(--muted)}.dash-log-row{display:flex;align-items:center;gap:12px;padding:10px 0;border-bottom:1px solid var(--border)}.dash-log-icon{width:28px;height:28px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.log-in{background:var(--green-light);color:var(--green)}.log-out{background:var(--blue-light);color:var(--blue)}.log-fail{background:var(--red-light);color:var(--red)}.dash-log-info{flex:1;display:flex;flex-direction:column;gap:1px}.dash-log-name{font-size:14px;font-weight:600}.dash-log-action,.dash-log-time{font-size:12px;color:var(--muted)}.guide-add-wrap{padding:12px 16px;background:var(--surface);border-bottom:1px solid var(--border)}.guide-input{width:100%;border:1.5px solid var(--border);border-radius:8px;padding:10px 12px;font-size:14px;background:var(--surface);color:var(--text);resize:none;font-family:inherit;outline:none;margin-bottom:8px}.guide-input:focus{border-color:var(--blue)}.guide-row{display:flex;align-items:center;gap:10px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:12px 14px}.guide-code{flex:1;font-size:15px;font-weight:600;font-family:monospace}.validated-code{color:var(--green);text-decoration:line-through;opacity:.7}.guide-check{color:var(--green);font-size:18px;font-weight:700}.guide-row.validated{opacity:.7}.settings-list{flex:1;overflow-y:auto;padding:16px;display:flex;flex-direction:column;gap:4px}.settings-section-label{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--muted);padding:12px 4px 4px}.settings-user-card{display:flex;align-items:center;gap:14px;background:var(--surface);border-radius:var(--radius);border:1px solid var(--border);padding:14px;margin-bottom:6px}.settings-row{display:flex;align-items:center;gap:12px;background:var(--surface);border-radius:10px;border:1px solid var(--border);padding:14px 16px;cursor:pointer;text-align:left;width:100%}.settings-icon{font-size:18px;width:24px;text-align:center}.settings-label{flex:1;font-size:15px;font-weight:500;color:var(--text)}.toggle-switch{width:48px;height:26px;background:var(--border);border-radius:99px;border:none;cursor:pointer;position:relative;transition:background .2s;flex-shrink:0}.toggle-switch.on{background:var(--blue)}.toggle-thumb{position:absolute;top:3px;left:3px;width:20px;height:20px;background:#fff;border-radius:50%;transition:left .2s}.toggle-switch.on .toggle-thumb{left:25px}.color-picker{display:flex;gap:10px;flex-wrap:wrap}.color-swatch{width:32px;height:32px;border-radius:50%;border:3px solid transparent;cursor:pointer}.color-swatch.active{border-color:var(--text);box-shadow:0 0 0 2px var(--bg)}.form-error{color:#dc2626;font-size:13px;font-weight:500}.form-actions{display:flex;gap:10px;justify-content:flex-end;margin-top:8px}.admin-confirm{flex:1;display:flex;align-items:center;justify-content:center;padding:24px}.confirm-card{background:var(--surface);border-radius:16px;border:1px solid var(--border);padding:28px 24px;display:flex;flex-direction:column;align-items:center;gap:12px;max-width:320px;width:100%;box-shadow:var(--shadow)}.confirm-title{font-size:18px;font-weight:700}.confirm-name{font-size:16px;font-weight:600}.confirm-hint{font-size:13px;color:var(--muted);text-align:center;line-height:1.5}.hist-item-header{display:flex;align-items:center;gap:12px;padding:14px;background:none;border:none;width:100%;text-align:left;cursor:pointer}.hist-item-header:active{background:#f8fafc}.result-badge{width:32px;height:32px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;flex-shrink:0;color:#fff}.badge-match{background:var(--green)}.badge-fail{background:var(--red)}.hist-meta{flex:1;min-width:0;display:flex;flex-direction:column;gap:2px}.hist-codes{font-size:14px;font-weight:700;font-family:Courier New,monospace;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.hist-user-time{font-size:12px;color:var(--muted)}.hist-chevron{color:#cbd5e1;font-size:12px}.hist-detail{border-top:1px solid var(--border);padding:14px;display:flex;flex-direction:column;gap:14px;background:#fafafa}.hist-codes-detail{display:flex;align-items:center;gap:10px}.hist-code-block{flex:1;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px}.hcd-label{display:block;font-size:11px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--muted);margin-bottom:3px}.hcd-val{font-family:Courier New,monospace;font-size:14px;font-weight:700;word-break:break-all}.hcd-eq{font-size:20px;font-weight:900;flex-shrink:0}.hcd-eq.eq-ok{color:var(--green)}.hcd-eq.eq-fail{color:var(--red)}.hist-photos{display:grid;grid-template-columns:1fr 1fr;gap:10px}.photo-wrap{display:flex;flex-direction:column;gap:5px}.photo-label{font-size:12px;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.5px}.hist-photo{width:100%;aspect-ratio:4/3;object-fit:cover;border-radius:8px;border:1px solid var(--border)}.hist-user-detail{display:flex;align-items:center;gap:10px;background:#fff;border:1px solid var(--border);border-radius:10px;padding:10px 12px}.hud-name{font-size:14px;font-weight:600}.hud-time{font-size:12px;color:var(--muted)}.hist-footer{padding:12px 16px 24px;text-align:center}.confirm-clear{display:flex;flex-direction:column;align-items:center;gap:10px;padding:12px;background:var(--red-light);border-radius:var(--radius);border:1px solid #fca5a5}.confirm-clear p{font-size:14px;font-weight:600;color:var(--red)}.confirm-btns{display:flex;gap:8px}
