: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}*,:before,:after{box-sizing:border-box}html,body,#root{width:100%;min-width:320px;min-height:100%}html,body{overflow-x:hidden}body{min-height:100vh;margin:0}img,video,canvas,svg{max-width:100%;display:block}button,input,select,textarea{max-width:100%;font:inherit}button{cursor:pointer}a{color:inherit}code{overflow-wrap:anywhere;background:#e8edf5;border-radius:6px;padding:2px 6px}h1,h2,h3,p,span,strong,label,button,a{overflow-wrap:anywhere}: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}:where(h1,h2,h3,p,strong,span,small,a,button,label){overflow-wrap:anywhere;word-break:break-word}.app-shell{width:100%;min-height:100vh;overflow-x:clip}.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;min-width:0;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{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:20px;min-width:0;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(280px,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;min-width:0;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{align-content:center;gap:14px;width:100%;min-width:0;display:grid}.scanner-instructions h1{max-width:12ch;margin:0;font-size:clamp(36px,5vw,60px);line-height:1.08}.scanner-instructions p{color:#c4d0e2;max-width:34rem;margin:0;font-size:17px;line-height:1.6}.scanner-mode-summary{align-content:start;justify-items:start;gap:12px;width:100%;max-width:360px;margin-bottom:0;display:grid}.scanner-mode-summary .eyebrow{margin:0}.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<=980px){.scanner-layout{grid-template-columns:minmax(0,1fr);max-width:720px}.scanner-instructions{text-align:center}.scanner-mode-summary{justify-items:center}.scanner-instructions p{max-width:680px;margin-left:auto;margin-right: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:minmax(0,1fr)}.scanner-panel{aspect-ratio:1}.scanner-instructions{text-align:center;justify-items:center}.scanner-mode-summary{justify-items:center;max-width:100%}.scanner-instructions h1{max-width:100%;font-size:38px}.scanner-instructions p{max-width:100%}.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;white-space:normal;overflow-wrap:anywhere;text-align:center;border-radius:999px;justify-content:center;align-items:center;width:fit-content;min-width:min(180px,100%);max-width:100%;margin:0;padding:13px 22px;font-size:clamp(20px,3vw,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}}.topbar-actions,.tab-bar,.subtab-bar,.profile-toolbar,.form-grid,.employee-row,.attendance-row,.profile-edit-layout,.profile-edit-form,.qr-batch-toolbar,.bulk-import-inputs,.attendance-filters{min-width:0}.topbar-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.tab-bar{scrollbar-width:thin;max-width:100%;overflow-x:auto}.tab-bar button,.subtab-bar button,.button{white-space:normal;overflow-wrap:anywhere}.employee-row>*,.attendance-row>*,.profile-edit-layout>*,.form-grid>*{min-width:0}.employee-info strong,.employee-info span,.attendance-row strong,.attendance-row span{overflow-wrap:anywhere}.profile-identity .employee-photo-placeholder{border-radius:24px;width:190px;height:190px;font-size:38px}.employee-row .employee-photo-placeholder{border-radius:14px;width:58px;height:58px;font-size:18px}.profile-danger-zone{background:#fff7f6;border:1px solid #fac7c3;border-radius:16px;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:16px;padding:18px;display:flex}.profile-danger-zone>div{flex:320px;min-width:0}.profile-danger-zone strong{color:var(--danger);display:block}.profile-danger-zone p{color:#7a3a35;margin:5px 0 0;font-size:13px;line-height:1.5}.button-danger-solid{color:#fff;background:var(--danger)}@media (width<=640px){.topbar{flex-wrap:wrap;gap:10px;height:auto;min-height:74px;padding-top:10px;padding-bottom:10px}.scanner-page{min-height:calc(100vh - 84px)}.scanner-heading{flex-wrap:wrap}.scanner-instructions h1{font-size:clamp(34px,12vw,46px)}.movement-mode-badge{width:min(100%,260px);min-width:0}.card{border-radius:18px;padding:20px}.profile-danger-zone{align-items:stretch}.profile-danger-zone .button{width:100%}}.mobile-tab-select-wrap{display:none}.admin-content{width:100%;min-width:0}.admin-content>*{width:100%}.admin-users-layout{grid-template-columns:minmax(0,.95fr) minmax(0,1.05fr);align-items:start;gap:18px;display:grid}.admin-user-form-card,.admin-user-list-card{min-width:0}.admin-user-form{gap:16px;margin-top:18px;display:grid}.admin-user-help{margin:6px 0 0}.password-generator-row{flex-wrap:wrap;gap:10px;display:flex}.password-status{color:var(--muted);background:#f1f4f8;border-radius:12px;padding:10px 12px;font-size:13px}.password-status.valid{color:#075f41;background:#e5f8ef}.admin-account-list{gap:10px;margin-top:20px;display:grid}.admin-account-row{border:1px solid var(--border);border-radius:16px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;padding:13px;display:grid}.admin-account-avatar{background:linear-gradient(145deg, var(--blue), var(--navy));color:#fff;border-radius:14px;place-items:center;width:46px;height:46px;font-size:19px;font-weight:900;display:grid}.admin-account-info{min-width:0}.admin-account-info strong,.admin-account-info span,.admin-account-info small{display:block}.admin-account-info span,.admin-account-info small{color:var(--muted);overflow-wrap:anywhere;margin-top:3px}.admin-account-info span{font-size:13px}.admin-account-info small{font-size:11px;line-height:1.45}@media (width<=960px){.admin-users-layout{grid-template-columns:1fr}}@media (width<=760px){input,select,textarea{min-height:48px;font-size:16px}textarea{min-height:96px}.button{min-height:44px}.desktop-tab-bar{display:none}.mobile-tab-select-wrap{z-index:18;border:1px solid var(--border);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#edf2f8f5;border-radius:15px;gap:6px;margin:14px 0 16px;padding:10px;display:grid;position:sticky;top:74px;box-shadow:0 8px 24px #081a3614}.mobile-tab-select{min-height:50px;color:var(--navy);background:#fff;font-weight:800}.admin-page{width:min(100% - 20px,1120px);margin:16px auto 48px}.admin-heading{gap:12px}.admin-heading h1{font-size:clamp(25px,8vw,34px);line-height:1.08}.admin-signout{width:100%}.card{border-radius:18px;padding:17px;box-shadow:0 14px 34px #081a3617}.list-card,.employee-form,.attendance-history-card,.security-card,.bulk-import-card,.qr-batch-page{max-width:none}.section-heading{align-items:flex-start;gap:12px}.section-heading>.button,.section-heading>.button-row{width:100%}.section-heading>.button-row .button{flex:150px}.form-grid,.admin-password-grid{grid-template-columns:1fr;gap:14px}.full-field{grid-column:auto}.button-row-left{grid-template-columns:1fr;width:100%;display:grid}.button-row-left .button{width:100%}.employee-list,.attendance-list{gap:12px}.employee-row{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:11px;padding:13px;display:grid}.employee-row .button{grid-column:1/-1;width:100%;margin:2px 0 0}.attendance-row{grid-template-columns:auto minmax(0,1fr);align-items:start;gap:11px;padding:13px;display:grid}.attendance-time{text-align:left;border-top:1px solid var(--border);grid-column:1/-1;grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:5px 12px;padding-top:9px;display:grid}.attendance-time .attendance-edit-button{grid-column:1/-1;width:100%;margin-top:5px}.attendance-filters{grid-template-columns:1fr;gap:12px}.attendance-search,.attendance-filter-button{grid-column:auto}.quick-date-buttons{grid-template-columns:1fr 1fr;gap:8px;display:grid}.quick-date-buttons .button{width:100%}.profile-toolbar{grid-template-columns:1fr}.profile-toolbar .button{width:100%}.modal-backdrop{place-items:stretch stretch;padding:0}.profile-modal,.compact-modal{border:0;border-radius:0;width:100%;height:100dvh;min-height:100dvh;max-height:none;padding:18px;overflow-y:auto}.modal-close{z-index:2;position:sticky;top:0}.profile-edit-layout{gap:18px;margin-top:14px}.profile-identity>img,.profile-identity>.employee-photo-placeholder{border-radius:22px;width:148px;height:148px}.profile-identity .qr-box canvas{width:min(210px,70vw)!important;height:auto!important}.profile-danger-zone{padding:14px}.subtab-bar{grid-template-columns:1fr;width:100%;display:grid}.subtab-bar button{min-height:46px}.device-row{grid-template-columns:1fr;align-items:stretch}.device-row .button{width:100%}.audit-row{grid-template-columns:1fr}.audit-row time{justify-self:start}.audit-row pre{white-space:pre-wrap;overflow-wrap:anywhere;max-width:calc(100vw - 62px)}.qr-batch-toolbar{grid-template-columns:1fr}.qr-batch-toolbar input{grid-column:auto}.inline-check{white-space:normal;min-height:44px}.bulk-import-inputs{grid-template-columns:1fr}.import-preview-wrap{margin-inline:-4px}.admin-account-row{grid-template-columns:auto minmax(0,1fr);align-items:start}.admin-account-row>.device-status{text-align:center;grid-column:1/-1;justify-self:stretch}.password-generator-row{grid-template-columns:1fr;display:grid}.password-generator-row .button{width:100%}}@media (width<=640px){.mobile-tab-select-wrap{top:84px}.topbar-actions .button,.topbar-actions .admin-link{align-items:center;min-height:42px;display:inline-flex}.scanner-page{padding:16px 12px 32px}.scanner-heading{margin-bottom:16px}.movement-selector{margin-bottom:18px;padding:6px}.scanner-layout{gap:20px}.scanner-instructions{gap:10px}.scanner-instructions h1{max-width:none;font-size:clamp(32px,11vw,44px)}.scanner-instructions p{font-size:15px;line-height:1.5}.result-card{border-radius:22px;padding:24px 17px}.result-card img{width:132px;height:132px}.result-time{font-size:23px}}@media (width<=430px){.brand{gap:8px}.brand-mark{border-radius:11px;width:38px;height:38px}.brand strong{font-size:14px}.admin-link{font-size:13px}.quick-date-buttons{grid-template-columns:1fr}.credential-preview>img,.employee-photo-placeholder.large{width:170px;height:170px}.qr-print-card{padding:13px}}
