:root{color:#10213c;font-synthesis:none;text-rendering:optimizelegibility;background:#edf2f8;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{min-width:320px;min-height:100%}body{min-width:320px;min-height:100vh;margin:0}button,input,select{font:inherit}button{cursor:pointer}a{color:inherit}code{background:#e8edf5;border-radius:6px;padding:2px 6px}:root{--navy:#081a36;--blue:#1455d9;--blue-dark:#0d3ca3;--sky:#dce8ff;--surface:#fff;--muted:#66748b;--border:#dbe3ef;--success:#087a51;--danger:#b42318;--warning:#b85c00;--shadow:0 22px 55px #081a361f}.app-shell{min-height:100vh}.topbar{border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(16px);backdrop-filter:blur(16px);z-index:20;background:#fffffff0;justify-content:space-between;align-items:center;height:74px;padding:0 5vw;display:flex;position:sticky;top:0}.brand{align-items:center;gap:12px;text-decoration:none;display:flex}.brand-mark{background:linear-gradient(145deg, var(--blue), var(--navy));color:#fff;border-radius:13px;place-items:center;width:42px;height:42px;font-size:22px;font-weight:900;display:grid}.brand strong{letter-spacing:.08em;display:block}.brand small{color:var(--muted);margin-top:2px;display:block}.admin-link{color:var(--muted);font-size:14px;text-decoration:none}.centered-page{place-items:center;min-height:calc(100vh - 74px);padding:32px 18px;display:grid}.scanner-background{background:radial-gradient(circle at top, #173d78, var(--navy))}.card{background:var(--surface);box-shadow:var(--shadow);border:1px solid #dbe3efe6;border-radius:24px;padding:28px}.login-card,.setup-card{width:min(460px,100%)}.card h1,.card h2{margin:8px 0 10px}.card p{color:var(--muted);line-height:1.55}.eyebrow{text-transform:uppercase;color:var(--blue);letter-spacing:.12em;font-size:12px;font-weight:800}label{color:#2a3b55;gap:7px;font-size:14px;font-weight:700;display:grid}input,select,textarea{color:#15243c;background:#fff;border:1px solid #cfd9e7;border-radius:12px;outline:none;width:100%;padding:12px 13px;transition:border .2s,box-shadow .2s}input:focus,select:focus,textarea:focus{border-color:var(--blue);box-shadow:0 0 0 4px #1455d91f}.login-card{gap:18px;display:grid}.button{border:0;border-radius:12px;padding:11px 16px;font-weight:800;transition:transform .15s,opacity .15s}.button:hover{transform:translateY(-1px)}.button:disabled{cursor:not-allowed;opacity:.55;transform:none}.button-primary{color:#fff;background:linear-gradient(135deg, var(--blue), var(--blue-dark))}.button-secondary{color:var(--navy);background:#e9eff8}.button-ghost{color:var(--blue);background:0 0;border:1px solid #cbd7eb;text-decoration:none}.button-danger-soft{color:var(--danger);background:#fff0ef}.button-small{padding:8px 12px;font-size:13px}.button-wide{width:100%;margin-top:22px}.button-row{flex-wrap:wrap;justify-content:center;gap:10px;display:flex}.notice{border-radius:12px;padding:12px 14px;font-size:14px;line-height:1.45}.notice-error{color:#8f1d17;background:#fff0ef;border:1px solid #fac7c3}.notice-warning{color:#744000;background:#fff5df;border:1px solid #f2d39a}.admin-page{width:min(1120px,100% - 36px);margin:42px auto 80px}.admin-heading,.section-heading{justify-content:space-between;align-items:center;gap:20px;display:flex}.admin-heading h1{margin:5px 0 0;font-size:clamp(28px,4vw,42px)}.tab-bar{background:#dfe6f0;border-radius:14px;flex-wrap:wrap;gap:4px;margin:28px 0 20px;padding:6px;display:inline-flex}.tab-bar button{color:#5f6d82;background:0 0;border:0;border-radius:10px;padding:10px 14px;font-weight:800}.tab-bar button.active{color:var(--navy);background:#fff;box-shadow:0 4px 12px #081a3614}.employee-form{max-width:900px}.section-heading h2{margin:5px 0 0}.status-pill,.counter{background:var(--sky);color:var(--blue-dark);border-radius:999px;padding:7px 11px;font-size:13px;font-weight:800}.counter{text-align:center;min-width:38px}.photo-capture{justify-items:center;padding:24px 0 10px;display:grid}.photo-button{width:180px;height:180px;color:var(--blue);background:#f2f6fb;border:2px dashed #9eb1ce;border-radius:50%;padding:18px;font-weight:800;overflow:hidden}.photo-button img{object-fit:cover;border-radius:50%;width:100%;height:100%}.photo-capture p{text-align:center;margin:10px 0;font-size:13px}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:18px;display:grid}.visually-hidden{opacity:0;pointer-events:none;width:1px;height:1px;position:absolute}.success-card{text-align:center;max-width:650px}.success-icon{width:58px;height:58px;color:var(--success);background:#dff8ed;border-radius:50%;place-items:center;margin:0 auto 12px;font-size:28px;font-weight:900;display:grid}.credential-preview{flex-wrap:wrap;justify-content:center;align-items:center;gap:25px;margin:25px 0;display:flex}.credential-preview>img{object-fit:cover;background:#eef2f7;border-radius:22px;width:220px;height:220px}.qr-box{border:1px solid var(--border);background:#fff;border-radius:18px;padding:4px}.list-card{max-width:930px}.employee-list,.attendance-list{gap:10px;margin-top:22px;display:grid}.employee-row,.attendance-row{border:1px solid var(--border);border-radius:16px;align-items:center;gap:14px;padding:12px;display:flex}.employee-row img{object-fit:cover;background:#eef2f7;border-radius:14px;width:58px;height:58px}.employee-info,.attendance-row>div:nth-child(2){flex:1;min-width:0}.employee-info strong,.employee-info span,.attendance-row strong,.attendance-row span{display:block}.employee-info span,.attendance-row span{color:var(--muted);margin-top:3px;font-size:13px}.movement-icon{border-radius:12px;place-items:center;width:42px;height:42px;font-weight:900;display:grid}.movement-icon.entry{color:var(--success);background:#dff8ed}.movement-icon.exit{color:#45546b;background:#e8edf6}.attendance-time{text-align:right}.scanner-page{background:radial-gradient(circle at 20% 0, #193f7b, var(--navy) 55%);color:#fff;min-height:calc(100vh - 74px);padding:30px 5vw 50px}.scanner-heading{color:#cbd7e9;text-transform:capitalize;justify-content:space-between;gap:15px;margin-bottom:24px;display:flex}.scanner-heading>div{align-items:center;gap:9px;display:flex}.live-dot{background:#48df9b;border-radius:50%;width:9px;height:9px;box-shadow:0 0 0 5px #48df9b21}.scanner-layout{grid-template-columns:minmax(320px,620px) minmax(260px,1fr);align-items:center;gap:clamp(28px,5vw,70px);width:min(1100px,100%);margin:0 auto;display:grid}.scanner-panel{aspect-ratio:4/3;background:#020812;border-radius:28px;position:relative;overflow:hidden;box-shadow:0 28px 80px #00000052}.qr-reader{width:100%;height:100%}.qr-reader video{object-fit:cover;width:100%!important;height:100%!important}.qr-reader>div:first-child{display:none!important}.scan-frame{pointer-events:none;aspect-ratio:1;border:3px solid #ffffffe6;border-radius:24px;width:min(58%,300px);position:absolute;inset:50% auto auto 50%;transform:translate(-50%,-50%);box-shadow:0 0 0 999px #0208125c}.scanner-overlay{color:#fff;z-index:4;background:#081426;place-items:center;display:grid;position:absolute;inset:0}.error-overlay{text-align:center;align-content:center;gap:10px;padding:30px}.error-overlay span{color:#c2ccdc}.scanner-instructions h1{margin:10px 0 16px;font-size:clamp(36px,5vw,60px);line-height:1.03}.scanner-instructions p{color:#c4d0e2;font-size:17px;line-height:1.6}.result-overlay{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);place-items:center;padding:20px;display:grid;position:fixed;inset:0}.result-overlay.success{background:#033929d1}.result-overlay.failure{background:#60100cdb}.result-card{width:min(530px,100%);color:var(--navy);text-align:center;background:#fff;border-radius:30px;padding:38px;box-shadow:0 30px 90px #00000059}.result-card img{object-fit:cover;border:6px solid #edf2f8;border-radius:50%;width:180px;height:180px;margin-bottom:18px}.result-symbol{width:110px;height:110px;color:var(--success);background:#e1f8ee;border-radius:50%;place-items:center;margin:0 auto 20px;font-size:55px;font-weight:900;display:grid}.result-card h2{margin:8px 0;font-size:clamp(28px,6vw,45px)}.result-card p{color:var(--muted)}.result-time{margin-top:16px;font-size:28px;display:block}.late-badge{color:var(--warning);background:#fff0d8;border-radius:999px;margin-top:14px;padding:8px 12px;font-weight:800;display:inline-block}.notice-success{color:#075f41;background:#e5f8ef;border:1px solid #a8e1c9}textarea{resize:vertical;font:inherit}.security-card{gap:20px;display:grid}.security-form{gap:18px;max-width:720px;display:grid}.button-row-left{justify-content:flex-start}.security-notes{color:var(--muted);background:#f2f6fb;border-radius:16px;gap:8px;padding:18px;display:grid}.security-notes strong{color:var(--navy)}.device-list{gap:10px;margin-top:8px;display:grid}.device-list h3{margin:0 0 4px}.device-row{border:1px solid var(--border);border-radius:14px;grid-template-columns:minmax(0,1fr) auto auto;align-items:center;gap:12px;padding:12px;display:grid}.device-row strong,.device-row span{display:block}.device-row div span{color:var(--muted);margin-top:4px;font-size:12px}.device-status{border-radius:999px;padding:6px 9px;font-size:12px;font-weight:800}.device-status.active{color:var(--success);background:#dff8ed}.device-status.inactive{color:#637086;background:#eef1f5}.audit-list{gap:12px;margin-top:22px;display:grid}.audit-row{border:1px solid var(--border);border-radius:16px;grid-template-columns:minmax(0,1fr) auto;gap:8px 18px;padding:14px;display:grid}.audit-row strong,.audit-row span{display:block}.audit-row span,.audit-row time{color:var(--muted);margin-top:4px;font-size:13px}.audit-row details{grid-column:1/-1}.audit-row summary{cursor:pointer;color:var(--blue);font-weight:700}.audit-row pre{color:#e7eef8;background:#081a36;border-radius:12px;max-height:260px;padding:12px;font-size:12px;overflow:auto}@media (width<=760px){.topbar{padding:0 18px}.brand small{display:none}.scanner-page{padding:20px 16px 40px}.scanner-heading{font-size:13px}.scanner-layout{grid-template-columns:1fr}.scanner-panel{aspect-ratio:1}.scanner-instructions{text-align:center}.scanner-instructions h1{font-size:38px}.form-grid{grid-template-columns:1fr}.admin-heading{flex-direction:column;align-items:flex-start}.employee-row{flex-wrap:wrap;align-items:flex-start}.employee-info{min-width:calc(100% - 80px)}.employee-row .button{margin-left:72px}.device-row,.audit-row{grid-template-columns:1fr}.audit-row details{grid-column:1}}.audit-workspace{gap:16px;display:grid}.subtab-bar{background:#e8edf5;border-radius:13px;gap:5px;width:fit-content;max-width:100%;padding:5px;display:inline-flex}.subtab-bar button{color:var(--muted);background:0 0;border:0;border-radius:9px;padding:9px 13px;font-weight:800}.subtab-bar button.active{color:var(--navy);background:#fff;box-shadow:0 4px 12px #081a3614}.profile-toolbar{grid-template-columns:minmax(0,1fr) auto;gap:10px;margin-top:20px;display:grid}.employee-info span+span{margin-top:5px}.modal-backdrop{z-index:120;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#040f22ad;place-items:center;padding:24px;display:grid;position:fixed;inset:0;overflow:auto}.profile-modal{width:min(1060px,100%);max-height:calc(100vh - 48px);overflow:auto}.modal-close{width:42px;height:42px;color:var(--navy);background:#edf1f7;border:0;border-radius:50%;font-size:28px;line-height:1}.profile-edit-layout{grid-template-columns:250px minmax(0,1fr);align-items:start;gap:28px;margin-top:22px;display:grid}.profile-identity{justify-items:center;gap:15px;display:grid;position:sticky;top:0}.profile-identity>img{object-fit:cover;background:#eef2f7;border-radius:24px;width:190px;height:190px}.profile-identity .button-row,.profile-identity .button{width:100%}.profile-edit-form{gap:18px;display:grid}.attendance-history-card{max-width:1020px}.attendance-filters{grid-template-columns:160px 160px minmax(220px,1fr) auto;align-items:end;gap:12px;margin-top:20px;display:grid}.attendance-filter-button{min-height:43px}.quick-date-buttons{flex-wrap:wrap;gap:8px;margin:12px 0 4px;display:flex}@media (width<=900px){.profile-edit-layout{grid-template-columns:1fr}.profile-identity{position:static}.attendance-filters{grid-template-columns:1fr 1fr}.attendance-search,.attendance-filter-button{grid-column:1/-1}}@media (width<=560px){.subtab-bar{grid-template-columns:1fr;width:100%;display:grid}.profile-toolbar{grid-template-columns:1fr}.modal-backdrop{padding:10px}.profile-modal{max-height:calc(100vh - 20px);padding:20px}.attendance-filters{grid-template-columns:1fr}.attendance-search,.attendance-filter-button{grid-column:auto}}.employee-photo-placeholder{width:58px;height:58px;color:var(--blue-dark);letter-spacing:.04em;background:linear-gradient(145deg,#dce8ff,#eef3fb);border-radius:14px;flex:none;place-items:center;font-weight:900;display:grid}.employee-photo-placeholder.large{border-radius:22px;width:220px;height:220px}.profile-identity>.employee-photo-placeholder{border-radius:24px;width:190px;height:190px;font-size:38px}.offline-banner{color:#8f1d17;text-align:center;background:#fff0ef;border:1px solid #fac7c3;border-radius:14px;width:min(1100px,100%);margin:0 auto 16px;padding:12px 16px;font-weight:800}.live-dot.offline{background:#ef6a62;box-shadow:0 0 0 5px #ef6a6224}.movement-selector{background:#ffffff1a;border:1px solid #ffffff26;border-radius:20px;grid-template-columns:1fr 1fr;gap:10px;width:min(720px,100%);margin:0 auto 26px;padding:8px;display:grid}.movement-selector button{color:#dbe7f7;text-transform:uppercase;letter-spacing:.04em;background:#ffffff14;border:0;border-radius:15px;min-height:68px;font-size:clamp(16px,2vw,21px);font-weight:900}.movement-selector button.active.entry{color:#075f41;background:#dff8ed;box-shadow:0 8px 24px #0000002e}.movement-selector button.active.exit{color:#8f1d17;background:#ffe5df;box-shadow:0 8px 24px #0000002e}.movement-mode-badge{letter-spacing:.08em;border-radius:999px;justify-content:center;align-items:center;min-width:180px;margin:12px 0 4px;padding:13px 22px;font-size:24px;font-weight:950;display:inline-flex}.movement-mode-badge.entry{color:#075f41;background:#dff8ed}.movement-mode-badge.exit{color:#8f1d17;background:#ffe5df}.movement-entry .scan-frame{border-color:#75f0bd}.movement-exit .scan-frame{border-color:#ff9e8c}.bulk-import-card,.qr-batch-page{max-width:1100px}.bulk-import-inputs{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin:20px 0;display:grid}.import-summary{flex-wrap:wrap;gap:10px;margin:18px 0;display:flex}.import-summary span{color:#42536c;background:#edf3fb;border-radius:999px;padding:9px 12px;font-size:13px}.import-summary strong{color:var(--navy)}.import-preview-wrap{border:1px solid var(--border);border-radius:16px;overflow:auto}.import-preview{border-collapse:collapse;width:100%;min-width:850px;font-size:13px}.import-preview th,.import-preview td{border-bottom:1px solid var(--border);text-align:left;padding:11px 12px}.import-preview th{color:#35465f;background:#eef3fa;position:sticky;top:0}.import-preview tr.invalid td{color:#8f1d17;background:#fff2f1}.import-results{gap:8px;margin-top:24px;display:grid}.muted-text{color:var(--muted);font-size:13px}.qr-batch-toolbar{grid-template-columns:minmax(220px,1fr) auto auto auto;align-items:center;gap:10px;margin:20px 0 14px;display:grid}.inline-check{white-space:nowrap;align-items:center;gap:8px;display:flex}.inline-check input{width:auto}.qr-print-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:14px;margin-top:20px;display:grid}.qr-print-card{border:1px solid var(--border);text-align:center;break-inside:avoid;background:#fff;border-radius:18px;justify-items:center;gap:4px;padding:16px;display:grid}.qr-print-card canvas{width:min(180px,100%)!important;height:auto!important}.qr-print-card strong{color:var(--navy);margin-top:5px}.qr-print-card span,.qr-print-card small{color:var(--muted)}.qr-print-card em{color:var(--danger);margin-top:4px;font-size:11px;font-style:normal;font-weight:800}.attendance-edit-button{margin-top:8px}.compact-modal{width:min(720px,100%);max-height:calc(100vh - 48px);overflow:auto}.full-field{grid-column:1/-1}@media (width<=900px){.bulk-import-inputs{grid-template-columns:1fr}.qr-batch-toolbar{grid-template-columns:1fr 1fr}.qr-batch-toolbar input{grid-column:1/-1}.qr-print-grid{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=600px){.movement-selector{grid-template-columns:1fr}.movement-selector button{min-height:58px}.qr-batch-toolbar{grid-template-columns:1fr}.qr-batch-toolbar input{grid-column:auto}.qr-print-grid{grid-template-columns:1fr}.full-field{grid-column:auto}}@media print{body{background:#fff!important}.topbar,.admin-heading,.tab-bar,.no-print{display:none!important}.admin-page{width:100%;margin:0}.card.qr-batch-page{box-shadow:none;border:0;max-width:none;padding:0}.qr-print-grid{grid-template-columns:repeat(3,1fr);gap:8mm;margin:0}.qr-print-card{border:1px solid #aaa;border-radius:4mm;padding:5mm}.qr-print-card canvas{width:42mm!important;height:42mm!important}@page{size:A4;margin:10mm}}.production-status-card{max-width:1020px}.production-verdict{border:1px solid var(--border);border-radius:16px;gap:4px;margin:18px 0;padding:18px 20px;display:grid}.production-verdict.ready{color:#14532d;background:#ecfdf3;border-color:#86efac}.production-verdict.not-ready{color:#7c2d12;background:#fff7ed;border-color:#fdba74}.production-checks{gap:10px;margin:18px 0;display:grid}.production-check{border:1px solid var(--border);background:#fff;border-radius:14px;grid-template-columns:38px 1fr;align-items:start;gap:12px;padding:14px 16px;display:grid}.production-check.ok{border-color:#bbf7d0}.production-check.failed{border-color:#fecaca}.production-check-symbol{border-radius:50%;place-items:center;width:32px;height:32px;font-weight:900;display:grid}.production-check.ok .production-check-symbol{color:#166534;background:#dcfce7}.production-check.failed .production-check-symbol{color:#991b1b;background:#fee2e2}.production-check p{margin:4px 0 0}
