:root{--bg:#eef2ef;--panel:#fff;--ink:#101820;--muted:#66727a;--line:#dfe7e3;--soft:#f6f8f7;--teal:#075f66;--teal-2:#0b7a73;--green:#33b457;--green-soft:#eaf8ef;--amber:#d98a05;--amber-soft:#fff5df;--red:#b42318;--shadow:0 28px 90px #1018202e}.adminShell{width:min(100%,760px);padding:14px 16px 18px}.adminCardHeader span,.fieldGroup span{font-size:13px}.fieldGroup input,.fieldGroup select,.adminPasswordBox input{min-height:44px;font-size:14px}.adminPasswordBox{min-height:46px}.adminSearchRow .outlineButton{min-height:46px;font-size:14px}.adminUserTable{width:100%;overflow:hidden}.adminUserRow>span{min-width:0;color:var(--muted);text-overflow:ellipsis;font-size:12px;line-height:1.25;overflow:hidden}@media (max-width:520px){.adminShell{padding:12px 8px 14px}.adminTopbar{grid-template-columns:1fr auto}.adminBrandTitle{grid-template-columns:74px minmax(0,1fr);gap:8px}.adminBrandTitle .brandLogo{width:74px}.adminBrandTitle h1{font-size:16px}.adminBrandTitle span,.adminTopActions .pill{display:none}.adminTopActions{justify-content:end}.adminTabs{margin-left:-8px;margin-right:-8px;padding-left:8px;padding-right:8px}.adminTabs button{min-height:54px;font-size:10px}.adminPageTitle h2{font-size:27px}.adminCard,.adminCard.wide{padding:10px}.adminSearchRow,.adminFilterBar,.historyControls{grid-template-columns:1fr}.adminUserTableHead{display:none}.adminUserRow{grid-template-columns:minmax(0,1fr) auto;gap:6px 10px;min-height:70px}.adminUserPerson{grid-column:1/2}.adminUserRow>span{display:none}.adminUserRow .pill{justify-self:end;font-size:10px}.adminIconActions{grid-column:1/-1;justify-content:end}.adminTableHead,.adminTableRow{grid-template-columns:minmax(108px,1.15fr) minmax(54px,.55fr) minmax(54px,.55fr) minmax(70px,.75fr);gap:4px;padding-left:6px;padding-right:6px}.adminTableHead{min-height:36px;font-size:10px}.adminTableRow{min-height:58px}.adminPersonCell{grid-template-columns:28px minmax(0,1fr);gap:5px}.adminPersonCell .adminAvatar{width:28px;height:28px;font-size:9px}.adminPersonCell strong,.adminTableRow>span{font-size:11px}.adminPersonCell span,.adminTableRow .pill{font-size:9px}.historyRow{grid-template-columns:1fr auto}}.adminShell{padding:18px 18px 20px}.adminLogin{padding-top:56px}.adminTopbar{gap:10px;padding:8px 0 12px}.adminBrandTitle{grid-template-columns:96px 1fr;gap:10px}.adminBrandTitle .brandLogo{width:96px}.adminBrandTitle h1{font-size:20px}.adminBrandTitle span{font-size:12px}.adminTopActions{gap:8px}.adminTopActions .pill{min-height:30px;padding:0 10px;font-size:12px}.adminTopActions .outlineButton{min-height:36px;padding:0 10px;font-size:14px}.adminTabs{margin-bottom:18px}.adminTabs button{gap:5px;min-height:62px;font-size:12px}.adminTabs button svg{width:18px;height:18px}.adminPanelStack{gap:14px}.adminPageTitle p{margin-top:5px;font-size:16px}.adminCardHeader{gap:8px}.adminCardHeader h2{font-size:20px}.adminCardHeader span{font-size:14px}.adminKpiGrid{gap:10px}.adminFilterBar{gap:10px}.adminFilterBar label,.adminFilterBar .outlineButton{min-height:46px;font-size:14px}.adminSummaryStrip span{font-size:14px}.adminTableHead{min-height:44px;padding:0 12px;font-size:13px}.adminPersonCell,.adminUserPerson{grid-template-columns:38px minmax(0,1fr);gap:9px}.adminPersonCell .adminAvatar,.adminUserPerson .adminAvatar{width:38px;height:38px;font-size:12px}.adminPersonCell strong,.adminUserPerson strong{font-size:15px}.adminPersonCell span,.adminUserPerson span{margin-top:2px;font-size:12px}.adminSearchRow{gap:10px}.adminSearchRow .outlineButton,.fieldGroup input,.fieldGroup select{min-height:46px;font-size:14px}.fieldGroup span{font-size:13px}.adminUserTableHead,.adminUserRow{grid-template-columns:minmax(180px,1.45fr) minmax(112px,.8fr) minmax(118px,.85fr) minmax(90px,.7fr) minmax(84px,.6fr)}.adminUserRow>span{font-size:13px}.enrollInstruction{min-height:88px;padding:14px 18px}.enrollInstruction span{font-size:14px}.enrollProgress span{min-height:72px;font-size:11px}@media (max-width:520px){.adminShell{padding:14px 10px 16px}.adminTopbar{grid-template-columns:1fr auto;align-items:center}.adminBrandTitle{grid-template-columns:82px minmax(0,1fr)}.adminBrandTitle .brandLogo{width:82px}.adminBrandTitle h1{font-size:18px}.adminTopActions{justify-content:end}.adminTopActions .pill{display:none}.adminTabs{margin-left:-10px;margin-right:-10px;padding-left:10px;padding-right:10px}.adminTabs button{min-height:58px;font-size:10px}.adminPageTitle h2{font-size:29px}.adminPageTitle p{font-size:15px}.adminKpiGrid{gap:8px}.adminKpiGrid .metric{min-height:92px;padding:10px}.adminKpiGrid .metric strong{font-size:28px}.adminSummaryStrip{padding:10px}.adminSummaryStrip strong{font-size:26px}.adminTableHead,.adminTableRow{grid-template-columns:minmax(120px,1.25fr) minmax(58px,.58fr) minmax(58px,.58fr) minmax(78px,.72fr);gap:5px;padding-left:8px;padding-right:8px}.adminTableHead{min-height:38px;font-size:11px}.adminTableRow{min-height:62px}.adminPersonCell{grid-template-columns:30px minmax(0,1fr);gap:6px}.adminPersonCell .adminAvatar{width:30px;height:30px;font-size:10px}.adminPersonCell strong{font-size:13px}.adminPersonCell span,.adminTableRow .pill{font-size:10px}.adminTableRow>span{font-size:12px}.adminTableRow .pill{min-height:28px;padding:4px}}*{box-sizing:border-box}html,body{min-height:100%;color:var(--ink);background:radial-gradient(circle at 0 0,#fff 0,#eef2ef 36%,#dfe8e5 100%);margin:0;font-family:Arial,Helvetica,sans-serif}button,input,select{font:inherit}button{cursor:pointer}.mockupStage{grid-template-columns:minmax(260px,390px) minmax(430px,1fr);place-items:center;gap:34px;min-height:100dvh;padding:30px;display:grid}.storyPanel{align-self:center;gap:18px;width:100%;display:grid}.brandLogo{object-fit:contain;width:180px;height:auto}.brandLogo.compact{object-fit:contain;width:46px;max-height:28px}.storyPanel h1,.storyPanel p{margin:0}.storyPanel h1{letter-spacing:0;max-width:360px;font-size:clamp(32px,5vw,54px);line-height:1}.storyPanel p{max-width:390px;color:var(--muted);font-size:16px;line-height:1.55}.appBadge,.safeBadge{width:fit-content;color:var(--teal);background:#e9f6f3;border:1px solid #075f6629;border-radius:999px;padding:8px 11px;font-size:13px;font-weight:800}.backendBadge{background:#ffffffb8;border:1px solid #075f6629;border-radius:8px;gap:4px;width:min(100%,390px);padding:12px;display:grid}.backendBadge strong{color:var(--teal)}.backendBadge span{color:var(--muted);font-size:13px}.screenPicker{grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;width:min(100%,390px);display:grid}.screenPicker button{border:1px solid var(--line);min-height:42px;color:var(--muted);background:#ffffffb8;border-radius:8px;font-size:13px;font-weight:800}.screenPicker button.active{border-color:var(--teal);background:var(--teal);color:#fff}.phoneFrame{width:min(100%,430px);height:min(92dvh,900px);min-height:820px;box-shadow:var(--shadow);background:linear-gradient(135deg,#111,#3d4144 42%,#090909);border-radius:58px;padding:13px}.phoneScreen{background:#fbfcfb;border:1px solid #111;border-radius:45px;height:100%;position:relative;overflow:hidden}.statusBar{color:#050707;grid-template-columns:1fr auto 1fr;align-items:center;height:58px;padding:0 24px;font-size:18px;font-weight:800;display:grid}.dynamicIsland{background:#050505;border-radius:999px;width:118px;height:34px}.statusIcons{justify-content:flex-end;align-items:center;gap:8px;display:inline-flex}.bars,.wifi{background:linear-gradient(#111 20%,#0000 20% 40%,#111 40% 60%,#0000 60% 80%,#111 80%);border-radius:3px;width:18px;height:14px;display:inline-block}.wifi{background:0 0;border:3px solid #111;border-color:#0000 #111 #111 #0000;width:16px;transform:rotate(225deg)}.battery{color:#fff;text-align:center;background:#111;border-radius:5px;min-width:28px;padding:2px 4px;font-size:12px}.appHeader{border-bottom:1px solid var(--line);background:#ffffffdb;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;height:74px;padding:0 22px;display:grid}.appHeader h1,.appHeader span{margin:0}.appHeader h1{letter-spacing:0;font-size:25px;line-height:1.1}.appHeader span{color:var(--muted);font-size:12px;font-weight:800;display:block}.brandMark,.iconButton{border:0;border-radius:12px;place-items:center;width:42px;height:42px;display:inline-grid}.brandMark{color:var(--ink);border:1px solid var(--line);background:#fff;overflow:hidden}.iconButton{background:var(--soft);color:var(--teal)}.iconButton.ghost{color:var(--muted);background:0 0}.content,.verifyContent{height:calc(100% - 218px);padding:20px 20px 22px;overflow:auto}.verifyContent{background:#fff;grid-template-rows:auto auto minmax(0,1fr) auto;height:calc(100% - 132px);padding:10px 0 0;display:grid;overflow:hidden}.content.centered{text-align:center;align-content:center;gap:18px;display:grid}.content.resultContent{height:calc(100% - 144px);padding-top:18px}.employeeMini{grid-template-columns:auto 1fr;align-items:center;gap:12px;display:grid}.avatar,.photoMock{width:58px;height:58px;color:var(--teal);background:linear-gradient(145deg,#dfe8e7,#b6d5cf);border-radius:16px;place-items:center;font-weight:900;display:grid}.avatar.large{border-radius:18px;flex:none;width:68px;height:68px;font-size:19px}.photoMock{border-radius:14px;width:96px;height:96px;font-size:24px}.photoMock.large{border-radius:28px;width:104px;height:104px;margin:0 auto}.employeeMini strong,.employeeMini span{display:block}.employeeMini strong{font-size:18px}.employeeMini span,.sectionBlock p,.stateCard span,.locationCard small,.receiptHeader span,.profileHero span,.listButton small{color:var(--muted)}.hello{justify-content:space-between;align-items:center;gap:16px;display:flex}.todayBadge{background:var(--soft);color:var(--muted);border-radius:999px;padding:8px 10px;font-size:13px;font-weight:800}.heroStatus,.sectionBlock,.stateCard,.infoCard,.locationCard,.challengePreview,.employeeCard,.verificationSummary,.receiptCard,.hoursCard,.chartCard,.profileHero,.loginHero{border:1px solid var(--line);background:#fff;border-radius:8px;box-shadow:0 8px 26px #1018200a}.loginContent{align-content:center;gap:14px;height:calc(100% - 132px);display:grid;overflow:hidden}.loginHero{text-align:center;justify-items:center;gap:12px;padding:24px 18px;display:grid}.loginHero h2,.loginHero p{margin:0}.loginHero h2{font-size:28px}.loginHero p{color:var(--muted);line-height:1.45}.employeeLoginHeader{background:#fff;border-bottom:0}.employeeLoginHeader .iconButton{color:var(--teal);background:#f7fbfa;border:1px solid #e5eeeb}.employeeLoginHeader h1{color:var(--ink)}.employeeLoginHeader .pill{background:#edf8f6}.employeeLoginContent{background:#fff;align-content:start;gap:16px;padding-top:14px}.employeeLoginHero{box-shadow:none;background:0 0;border:0;gap:16px;padding:22px 14px 20px}.employeeLoginHero .brandLogo{filter:drop-shadow(0 14px 22px #1018201f);width:min(72vw,260px);height:auto}.employeeLoginHero h2{color:var(--teal);font-size:clamp(32px,7.5vw,40px);line-height:1.04}.employeeLoginHero p{max-width:320px;color:var(--muted);font-size:17px;line-height:1.45}.employeeLoginForm{border-color:#d6e3df;margin-top:0;padding:16px;box-shadow:0 14px 38px #1018200f}.employeeLoginForm .fieldGroup input{background:#fff;border-color:#b8c5cb;min-height:58px;font-size:16px}.employeeLoginForm .primaryButton{min-height:54px;margin-top:2px}.employeeLoginTrust{background:#fff;border-color:#d6e3df;margin-top:0;box-shadow:0 12px 34px #1018200d}.accessChoiceGrid{gap:12px;display:grid}.accessChoice{border:1px solid var(--line);min-height:118px;color:var(--ink);text-align:left;background:#fff;border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:6px 14px;padding:16px;display:grid}.accessChoice svg{color:var(--teal);grid-row:span 2}.accessChoice strong,.accessChoice span{display:block}.accessChoice strong{font-size:20px}.accessChoice span{color:var(--muted);line-height:1.35}.fieldGroup{gap:8px;display:grid}.fieldGroup span{color:var(--muted);font-size:13px;font-weight:800}.fieldGroup input{border:1px solid var(--line);background:var(--soft);width:100%;min-height:52px;color:var(--ink);border-radius:8px;outline:none;padding:0 14px;font-size:18px;font-weight:800}.fieldGroup select{border:1px solid var(--line);background:var(--soft);width:100%;min-height:52px;color:var(--ink);border-radius:8px;outline:none;padding:0 14px;font-weight:800}.fieldGroup input:focus,.fieldGroup select:focus{border-color:var(--teal);background:#fff;box-shadow:0 0 0 4px #075f661a}.heroStatus{gap:16px;margin-top:18px;padding:18px;display:grid}.heroStatus span,.challengePreview span,.hoursCard span{color:var(--muted);font-weight:800}.heroStatus h2,.challengePreview h2,.challengeInstruction h2,.content.centered h2,.resultContent h1,.receiptHeader h2,.profileHero h2{letter-spacing:0;margin:0}.heroStatus h2{margin-top:6px;font-size:30px}.primaryButton,.outlineButton,.dangerButton{border:0;border-radius:8px;justify-content:center;align-items:center;gap:10px;min-height:50px;font-weight:900;display:inline-flex}.primaryButton{background:linear-gradient(135deg, var(--teal), #004e56);color:#fff}.primaryButton:disabled{opacity:.58;cursor:wait}.primaryButton.large,.outlineButton,.dangerButton{width:100%}.outlineButton{border:1.5px solid var(--teal);color:var(--teal);background:#fff}.dangerButton{color:var(--red);background:#fff7f6;border:1px solid #f0c6c0}.twoCards,.metricRow,.metricGrid,.actionRow{gap:10px;display:grid}.twoCards{grid-template-columns:1fr 1fr;margin-top:14px}.infoCard{gap:7px;padding:14px;display:grid}.infoCard svg{color:var(--teal)}.infoCard span,.metric span{color:var(--muted);font-size:13px}.infoCard strong{font-size:15px}.sectionBlock{gap:12px;margin-top:14px;padding:16px;display:grid}.sectionBlock h3,.recordGroup h3{margin:0;font-size:17px}.sectionTitle{justify-content:space-between;align-items:center;gap:12px;display:flex}.metricRow{grid-template-columns:repeat(3,1fr)}.metricGrid{grid-template-columns:1fr 1fr}.metric{border:1px solid var(--line);background:var(--soft);border-radius:8px;align-content:center;gap:6px;min-height:78px;padding:12px;display:grid}.metric strong{font-size:27px}.metric.good strong,.checkRow svg,.stateCard svg,.listButton>svg:last-child{color:var(--green)}.metric.warn strong{color:var(--amber)}.stateCard,.locationCard{grid-template-columns:auto 1fr;align-items:center;gap:12px;margin-top:14px;padding:14px;display:grid}.locationCard{grid-template-columns:auto 1fr auto}.locationCard svg:first-child{color:var(--teal)}.locationCard span,.locationCard strong,.locationCard small,.stateCard strong,.stateCard span{display:block}.segmented{border:1px solid var(--line);border-radius:8px;grid-template-columns:1fr 1fr;display:grid;overflow:hidden}.segmented button{background:var(--soft);min-height:43px;color:var(--muted);border:0;font-weight:900}.segmented button.active{background:var(--teal);color:#fff}.challengePreview{grid-template-columns:auto 1fr;align-items:center;gap:14px;margin:14px 0;padding:17px;display:grid}.diceIcon,.arrowBadge{background:var(--amber-soft);width:56px;height:56px;color:var(--amber);border-radius:16px;place-items:center;font-weight:900;display:grid}.challengePreview p{color:var(--amber);margin:5px 0 0;font-size:22px;font-weight:900}.pill{background:var(--soft);width:fit-content;color:var(--muted);border-radius:999px;align-items:center;gap:6px;padding:7px 10px;font-size:12px;font-weight:900;display:inline-flex}.pill.good{background:var(--green-soft);color:#16883b}.pill.warn{background:var(--amber-soft);color:#956003}.pill.bad{color:var(--red);background:#fff1ef}.pill.teal{color:var(--teal);background:#e8f5f4}.steps{grid-template-columns:42px 1fr 42px 1fr 42px;align-items:center;gap:0;padding:0 26px;display:grid}.steps span{width:42px;height:42px;color:var(--ink);background:#e0e3e5;border-radius:50%;place-items:center;font-weight:900;display:grid}.steps span.done,.steps span.active{background:var(--green);color:#fff}.steps span.active{background:var(--teal)}.steps i{background:linear-gradient(90deg, var(--green), #dfe5e3);height:4px}.stepLabel{color:var(--teal);text-align:center;margin:10px 0 14px;font-size:18px;display:block}.cameraMock{background:linear-gradient(#0c121347,#0c121347),linear-gradient(135deg,#62736f,#2e3839 48%,#71827c);place-items:center;height:335px;display:grid;position:relative;overflow:hidden}.cameraMock.live{background:#192224}.verifyContent .cameraMock{height:auto;min-height:0}.liveVideo{object-fit:cover;width:100%;height:100%;position:absolute;inset:0;transform:scaleX(-1)}.cameraPlaceholder{z-index:1;color:#fff;text-align:center;background:linear-gradient(135deg,#334143,#111819);align-content:center;place-items:center;gap:10px;padding:28px;font-weight:800;display:grid;position:absolute;inset:0}.cameraMock .pill{z-index:2;position:absolute;top:16px;left:16px}.faceOval{z-index:1;border:3px solid #fffffff0;border-radius:50%;place-items:center;width:245px;height:285px;display:grid;position:relative}.liveOval{background:#ffffff05;box-shadow:0 0 0 999px #0003}.faceShape{background:#d8aa84;border-radius:54% 46% 48% 52%;width:152px;height:205px;position:relative;transform:rotate(-7deg);box-shadow:inset -18px 0 #804a3224}.hair{background:#211915;border-radius:42px 42px 20px 20px;height:68px;position:absolute;inset:-28px -10px auto -8px}.ear{background:#c99070;border-radius:50%;width:26px;height:42px;position:absolute;top:82px;right:-16px}.eye,.nose,.mouth{background:#3e2b24;position:absolute}.eye{border-radius:999px;width:22px;height:6px;top:86px}.eye.left{left:34px}.eye.right{right:38px}.nose{background:#a9785e;border-radius:99px;width:8px;height:38px;top:108px;left:75px}.mouth{border-radius:999px;width:46px;height:7px;bottom:38px;left:57px}.landmark{background:#fff;border-radius:50%;width:8px;height:8px;position:absolute;box-shadow:0 0 0 1px #075f662e}.l1{top:92px;left:64px}.l2{top:96px;right:72px}.l3{top:148px;left:115px}.l4{bottom:82px;left:82px}.l5{bottom:78px;right:78px}.corner{border-color:#fff;width:44px;height:44px;position:absolute}.topLeft{border-top:4px solid;border-left:4px solid;top:82px;left:26px}.topRight{border-top:4px solid;border-right:4px solid;top:82px;right:26px}.bottomLeft{border-bottom:4px solid;border-left:4px solid;bottom:38px;left:26px}.bottomRight{border-bottom:4px solid;border-right:4px solid;bottom:38px;right:26px}.captureCue{z-index:4;color:#fff;text-align:center;background:#0912146b;align-content:center;place-items:center;gap:10px;padding:28px;display:grid;position:absolute;inset:0}.motionGuide{z-index:3;color:#fff;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);pointer-events:none;background:#0511136b;border:1px solid #ffffff47;border-radius:8px;align-content:center;justify-items:center;gap:8px;width:116px;min-height:124px;padding:10px;display:grid;position:absolute;bottom:14px;right:14px}.motionGuide.locked{opacity:.72}.motionHead{transform-origin:bottom;background:#ffffff14;border:2px solid #ffffffe6;border-radius:48% 48% 52% 52%;width:54px;height:64px;position:relative;box-shadow:0 0 0 10px #ffffff0a}.motionEye,.motionMouth{background:#fff;position:absolute}.motionEye{border-radius:50%;width:6px;height:6px;top:25px}.motionEye.left{left:16px}.motionEye.right{right:16px}.motionMouth{border-radius:999px;width:16px;height:3px;bottom:18px;left:19px}.motionSignal{color:#ffffffeb;text-align:center;place-items:center;min-height:18px;font-size:11px;font-weight:900;display:grid;position:relative}.motionGuide.turn_left .motionHead{animation:1.45s ease-in-out infinite guideTurnLeft}.motionGuide.turn_right .motionHead{animation:1.45s ease-in-out infinite guideTurnRight}.motionGuide.blink .motionEye{animation:1.25s ease-in-out infinite guideBlink}.motionGuide.smile .motionMouth{background:0 0;border:2px solid #fff;border-top:0;height:8px;animation:1.3s ease-in-out infinite guideSmile}.motionGuide.move_closer .motionHead{animation:1.4s ease-in-out infinite guideCloser}.motionGuide.turn_left:after,.motionGuide.turn_right:after,.motionGuide.move_closer:after{content:"";opacity:.9;border-top:3px solid #fff;border-right:3px solid #fff;width:28px;height:28px;position:absolute}.motionGuide.turn_left:after{animation:1.45s ease-in-out infinite guideArrowLeft;top:46px;left:13px;transform:rotate(-135deg)}.motionGuide.turn_right:after{animation:1.45s ease-in-out infinite guideArrowRight;top:46px;right:13px;transform:rotate(45deg)}.motionGuide.move_closer:after{animation:1.4s ease-in-out infinite guideArrowCloser;top:20px;transform:rotate(-45deg)}@keyframes guideTurnLeft{0%,to{transform:translate(0)rotateY(0)}50%{transform:translate(-10px)rotateY(-34deg)}}@keyframes guideTurnRight{0%,to{transform:translate(0)rotateY(0)}50%{transform:translate(10px)rotateY(34deg)}}@keyframes guideBlink{0%,62%,to{height:6px;transform:translateY(0)}72%,82%{height:2px;transform:translateY(2px)}}@keyframes guideSmile{0%,to{width:16px;transform:translate(0)}50%{width:28px;transform:translate(-6px)}}@keyframes guideCloser{0%,to{transform:scale(.88)}50%{transform:scale(1.12)}}@keyframes guideArrowLeft{0%,to{opacity:.25;translate:12px}50%{opacity:1;translate:0}}@keyframes guideArrowRight{0%,to{opacity:.25;translate:-12px}50%{opacity:1;translate:0}}@keyframes guideArrowCloser{0%,to{opacity:.2;translate:0 10px;scale:.8}50%{opacity:1;translate:0;scale:1}}.captureCue span,.captureCue small{text-shadow:0 1px 8px #00000059;font-weight:900}.captureCue span{text-transform:uppercase;font-size:15px}.captureCue strong{color:#fff;text-shadow:0 2px 16px #00000073;max-width:100%;font-size:clamp(34px,10vw,74px);line-height:1}.captureCue small{font-size:18px}.captureMeter{background:#ffffff47;border-radius:999px;width:min(240px,70%);height:10px;overflow:hidden}.captureMeter i{border-radius:inherit;background:#38c163;height:100%;transition:width .16s;display:block}.challengePanel{border-top:1px solid var(--line);background:#fff;gap:9px;padding:12px 16px 16px;display:grid}.captureState,.inlineError,.emptyText{color:var(--muted);margin:0;font-size:13px;line-height:1.4}.inlineError{color:var(--red);font-weight:800}.successText{color:#16883b;margin:0;font-weight:800}.challengeInstruction{background:var(--soft);border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:14px;padding:12px;display:grid}.challengeInstruction.locked{background:linear-gradient(135deg,#f6fbfa,#eef8f6);border:1px dashed #075f663d}.challengeInstruction h2{font-size:24px}.challengeInstruction p{color:var(--muted);margin:4px 0 0;font-size:14px}.checkGrid{border:1px solid var(--line);border-radius:8px;grid-template-columns:repeat(3,1fr);display:grid;overflow:hidden}.checkGrid span{min-height:48px;color:var(--ink);text-align:center;justify-content:center;align-items:center;gap:6px;padding:6px;font-size:12px;font-weight:900;display:inline-flex}.checkGrid span+span{border-left:1px solid var(--line)}.checkGrid svg{color:var(--muted);background:#d9e4e2;border-radius:50%;flex:none;padding:2px}.checkGrid span.done svg{background:var(--green);color:#fff}.checkGrid span.active{color:var(--teal)}.checkGrid span.active svg{background:var(--teal);color:#fff}.smallLocation{color:var(--muted);align-items:center;gap:7px;font-weight:800;display:inline-flex}.spinnerRing{border:10px solid #e5efec;border-top-color:var(--teal);width:108px;height:108px;color:var(--teal);border-radius:50%;place-items:center;margin:0 auto;display:grid}.checkList{border:1px solid var(--line);text-align:left;background:#fff;border-radius:8px;display:grid;overflow:hidden}.checkRow{grid-template-columns:auto 1fr auto;align-items:center;gap:12px;min-height:56px;padding:12px 14px;display:grid}.checkRow+.checkRow{border-top:1px solid var(--line)}.spin{color:var(--teal);animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.successBurst{background:radial-gradient(circle, var(--green) 0 48%, #33b45721 49% 100%);color:#fff;border-radius:50%;place-items:center;width:128px;height:128px;margin:0 auto 14px;display:grid}.successBurst.warn{background:radial-gradient(circle, var(--amber) 0 48%, #d98a0524 49% 100%)}.resultContent h1{color:#04343b;text-align:center;font-size:34px}.timePill{border:1px solid var(--line);width:fit-content;color:var(--muted);border-radius:999px;align-items:center;gap:8px;margin:12px auto 16px;padding:8px 13px;font-size:20px;font-weight:900;display:inline-flex}.employeeCard{grid-template-columns:auto 1fr;align-items:center;gap:15px;padding:14px;display:grid}.employeeCard h2,.employeeCard span,.employeeCard strong{margin:0;display:block}.employeeCard h2{font-size:24px}.employeeCard span,.employeeCard strong{color:var(--muted);line-height:1.5}.verificationSummary{margin-top:8px;overflow:hidden}.reviewNote{background:var(--amber-soft);color:#bc7200;border-top:1px solid #f1dab0;padding:12px 14px;font-size:13px;font-weight:900}.reviewNote.bad{color:var(--red);background:#fff1ef;border-top-color:#f0c6c0}.listButton{border:1px solid var(--line);width:100%;min-height:58px;color:var(--ink);text-align:left;background:#fff;border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;margin-top:12px;padding:12px 14px;font-weight:900;display:grid}.listButton>svg:first-child{color:var(--teal)}.listButton span,.listButton small{min-width:0;display:block}.listButton span{text-overflow:ellipsis;overflow:hidden}.listButton.static{cursor:default}.listButton small{text-overflow:ellipsis;white-space:nowrap;margin-top:3px;font-size:12px;font-weight:800;overflow:hidden}.bottomNav{border-top:1px solid var(--line);background:#fffffff0;grid-template-columns:repeat(5,1fr);align-items:center;height:86px;padding:8px 12px 12px;display:grid;position:absolute;bottom:0;left:0;right:0}.bottomNav button{color:var(--muted);background:0 0;border:0;justify-items:center;gap:4px;font-size:12px;font-weight:900;display:grid}.bottomNav button span{border-radius:50%;place-items:center;width:34px;height:34px;display:grid}.bottomNav button.active{color:var(--teal)}.bottomNav .mainAction span{background:linear-gradient(145deg, var(--teal), #098077);color:#fff;width:58px;height:58px;margin-top:-22px;box-shadow:0 10px 26px #075f6647}.receiptCard{gap:12px;padding:16px;display:grid}.receiptHeader{color:var(--green);grid-template-columns:auto 1fr;align-items:center;gap:12px;display:grid}.receiptHeader h2{color:var(--ink)}.qrMock{border:1px solid var(--line);width:128px;height:128px;color:var(--teal);background:linear-gradient(90deg,#075f6614 50%,#0000 50%) 0 0/18px 18px,#fff;border-radius:8px;place-items:center;margin:8px auto;display:grid}.receiptRow{border-top:1px dashed var(--line);justify-content:space-between;gap:12px;padding-top:10px;display:flex}.receiptRow span{color:var(--muted)}.actionRow{grid-template-columns:1fr 1fr;margin:14px 0}.searchBox{border:1px solid var(--line);min-height:46px;color:var(--muted);background:#fff;border-radius:8px;align-items:center;gap:10px;padding:0 14px;font-weight:800;display:flex}.filterRow{flex-wrap:wrap;gap:8px;margin:12px 0;display:flex}.recordGroup{gap:10px;margin-top:14px;display:grid}.recordRow{border:1px solid var(--line);text-align:left;background:#fff;border-radius:8px;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;min-height:76px;padding:12px;display:grid}.recordIcon{background:var(--green-soft);width:42px;height:42px;color:var(--green);border-radius:12px;place-items:center;font-weight:900;display:grid}.recordIcon.warn{background:var(--amber-soft);color:var(--amber)}.recordRow strong,.recordRow span,.recordRow small{min-width:0;display:block}.recordRow span,.recordRow small{color:var(--muted);margin-top:3px}.recordRow>div:last-child{justify-items:end;display:grid}.recordRow>div:nth-child(2){min-width:0}.recordRow>div:nth-child(2) strong,.recordRow>div:nth-child(2) span{text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.hoursCard{gap:8px;margin-top:12px;padding:17px;display:grid}.hoursCard strong{color:var(--teal);font-size:32px}.chartCard{gap:11px;margin-top:12px;padding:16px;display:grid}.chartHint{color:var(--muted);margin:-2px 0 0;font-size:13px;font-weight:800;line-height:1.35}.barsChart{grid-template-columns:repeat(5,1fr);align-items:end;gap:9px;height:154px;padding:4px 2px 0;display:grid}.trendDay{grid-template-rows:22px minmax(74px,1fr) 18px;place-items:end center;gap:5px;min-width:0;height:100%;display:grid}.trendDay strong{color:var(--ink);font-size:12px;line-height:1}.trendDay span{background:#dfe8e7;border-radius:7px 7px 0 0;width:100%;max-width:42px;min-height:10px;display:block}.trendDay span.complete{background:linear-gradient(180deg, var(--teal-2), var(--teal))}.trendDay span.partial{background:linear-gradient(180deg, #d99a00, var(--amber))}.trendDay small{width:100%;color:var(--muted);text-align:center;text-overflow:ellipsis;text-transform:capitalize;white-space:nowrap;font-size:11px;font-weight:900;overflow:hidden}.chartLegend{color:var(--muted);flex-wrap:wrap;gap:7px 10px;font-size:11px;font-weight:900;display:flex}.chartLegend span{align-items:center;gap:5px;display:inline-flex}.chartLegend i{background:#dfe8e7;border-radius:50%;width:9px;height:9px}.chartLegend i.complete{background:var(--teal)}.chartLegend i.partial{background:var(--amber)}.profileHero{text-align:center;padding:20px}.employeeProfileHero{text-align:left;gap:14px;padding:14px;display:grid}.profileBrandStrip{justify-content:space-between;align-items:center;gap:12px;display:flex}.profileBrandStrip .brandLogo{width:156px;height:auto}.profileIdentity{grid-template-columns:auto minmax(0,1fr);align-items:center;gap:12px;display:grid}.profileIdentity h2,.profileIdentity span{min-width:0}.profileIdentity h2{text-overflow:ellipsis;white-space:nowrap;font-size:23px;line-height:1.08;overflow:hidden}.profileIdentity span{color:var(--muted);text-overflow:ellipsis;white-space:nowrap;margin-top:4px;font-size:13px;font-weight:800;display:block;overflow:hidden}.profileStatusGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin-top:12px;display:grid}.profileNotice{color:var(--teal);background:#eef9f8;border:1px solid #d4ecea;border-radius:8px;margin:10px 0 0;padding:10px 12px;font-size:13px;font-weight:800;line-height:1.35}.profileStat{border:1px solid var(--line);background:var(--soft);border-radius:8px;align-content:center;gap:5px;min-width:0;min-height:68px;padding:10px 12px;display:grid}.profileStat span{color:var(--muted);text-overflow:ellipsis;text-transform:uppercase;white-space:nowrap;font-size:11px;font-weight:900;overflow:hidden}.profileStat strong{color:var(--ink);text-overflow:ellipsis;white-space:nowrap;font-size:17px;line-height:1.1;overflow:hidden}.profileStat.good strong{color:var(--green)}.profileStat.warn strong{color:var(--amber)}.profileStat.teal strong{color:var(--teal)}.profileQuickActions{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;display:grid}.profileQuickActions .outlineButton{min-width:0;min-height:42px;font-size:13px}.profileLogo{place-items:center;width:min(100%,210px);height:96px;margin:0 auto;display:grid}.profileLogo .brandLogo{width:210px}.profileHero h2{margin-top:12px;font-size:25px}.adminShell{background:linear-gradient(#f4f7f5,#fff 62%);min-height:100dvh;padding:18px 14px 28px}.adminLogin{border:1px solid var(--line);width:min(100%,430px);min-height:520px;box-shadow:var(--shadow);background:#fff;border-radius:8px;align-content:center;gap:16px;margin:8dvh auto 0;padding:28px;display:grid}.adminLogin h1,.adminLogin p{margin:0}.adminLogin h1{font-size:32px;line-height:1.05}.adminLogin p,.adminTopbar span,.adminCardHeader span{color:var(--muted);line-height:1.45}.adminTopbar{border:1px solid var(--line);background:#fff;border-radius:8px;grid-template-columns:86px 1fr;align-items:center;gap:12px;max-width:680px;margin:0 auto 12px;padding:14px;display:grid;box-shadow:0 10px 26px #1018200f}.adminTopbar .brandLogo{width:86px;height:auto}.adminTopbar h1,.adminCardHeader h2{margin:0}.adminTopbar h1{font-size:22px;line-height:1.05}.adminTopActions{grid-column:1/-1;justify-content:space-between;align-items:center;gap:10px;display:flex}.adminTopActions .outlineButton{width:auto;min-height:40px;padding:0 14px}.adminGrid{grid-template-columns:1fr;align-items:start;gap:12px;max-width:680px;margin:0 auto;display:grid}.adminGrid.overview{grid-template-columns:1fr}.adminTabs{scrollbar-width:none;gap:8px;max-width:680px;margin:0 auto 12px;padding:2px 1px 8px;display:flex;overflow-x:auto}.adminTabs::-webkit-scrollbar{display:none}.adminTabs button{border:1px solid var(--line);min-height:44px;color:var(--muted);background:#fff;border-radius:8px;flex:none;justify-content:center;align-items:center;gap:7px;padding:0 13px;font-weight:900;display:inline-flex}.adminTabs button.active{border-color:var(--teal);background:var(--teal);color:#fff}.adminCard{border:1px solid var(--line);background:#fff;border-radius:8px;gap:13px;padding:14px;display:grid;box-shadow:0 10px 26px #1018200f}.adminCard.wide{max-width:680px;margin:0 auto}.adminGrid.usersGrid{grid-template-columns:1fr}.adminCardHeader{grid-template-columns:auto 1fr;align-items:center;gap:10px;display:grid}.adminCardHeader svg{color:var(--teal)}.adminList{gap:8px;max-height:360px;display:grid;overflow:auto}.adminEmployeeRow{border:1px solid var(--line);background:var(--soft);border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:10px;padding:10px;display:grid}.adminEmployeeRow strong,.adminEmployeeRow span{display:block}.adminEmployeeRow span{color:var(--muted);margin-top:3px;font-size:13px}.adminUserList{gap:9px;display:grid}.adminUserRow{border:1px solid var(--line);background:var(--soft);border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:11px;padding:12px;display:grid}.adminUserRow strong,.adminUserRow span,.adminUserRow small{display:block}.adminUserRow span,.adminUserRow small{color:var(--muted);margin-top:2px;font-size:13px}.adminAvatar{width:42px;height:42px;color:var(--teal);background:#e6f4f2;border-radius:8px;place-items:center;font-weight:950;display:grid}.adminAvatar.small{width:34px;height:34px;font-size:12px}.adminIconActions{grid-column:1/-1;gap:6px;display:flex}.adminIconActions button{border:1px solid var(--line);width:34px;height:34px;color:var(--muted);background:#fff;border-radius:8px;place-items:center;display:grid}.searchField{position:relative}.searchField input{padding-right:42px}.searchField svg{color:var(--muted);position:absolute;bottom:14px;right:14px}.adminCamera{background:#1c2729;border-radius:8px;place-items:center;height:clamp(340px,64dvh,520px);display:grid;position:relative;overflow:hidden}.adminCamera video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0;transform:scaleX(-1)}.adminCameraEmpty{z-index:1;color:#fff;justify-items:center;gap:8px;font-weight:800;display:grid;position:absolute}.adminCameraBadge{z-index:3;color:var(--teal);background:#ffffffe6;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:950;position:absolute;top:12px;left:12px}.adminFaceGuide{z-index:2;pointer-events:none;border:3px solid #ffffffeb;border-radius:50%;width:min(62vw,230px);height:min(76vw,290px);position:relative;box-shadow:0 0 0 999px #00000038}.enrollProgress{grid-template-columns:repeat(5,1fr);gap:7px;display:grid}.enrollProgress span{background:var(--soft);min-height:34px;color:var(--muted);text-align:center;border-radius:8px;place-items:center;padding:0 8px;font-size:12px;font-weight:900;display:grid}.enrollProgress span.active{background:var(--teal);color:#fff}.enrollProgress span.done{background:var(--green);color:#fff}.enrollInstruction{background:linear-gradient(135deg,#f6fbfa,#eef7f5);border:1px solid #cde5e1;border-radius:8px;grid-template-columns:auto 1fr;align-items:center;gap:4px 12px;padding:14px;display:grid}.enrollInstruction small{color:var(--teal);grid-column:1/-1;font-weight:900}.enrollInstruction strong{font-size:22px;line-height:1.05}.enrollInstruction span{color:var(--muted);grid-column:1/-1}.enrollEmployeeSummary{border:1px solid var(--line);background:var(--soft);border-radius:8px;grid-template-columns:auto 1fr auto;align-items:center;gap:12px;padding:12px;display:grid}.enrollEmployeeSummary strong,.enrollEmployeeSummary span{display:block}.enrollEmployeeSummary span{color:var(--muted);font-size:13px}.adminActions{grid-template-columns:1fr;gap:10px;display:grid}.adminKpiGrid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.adminFilterBar{grid-template-columns:1fr;align-items:center;gap:10px;display:grid}.adminFilterBar label{border:1px solid var(--line);background:var(--soft);min-height:42px;color:var(--teal);border-radius:8px;align-items:center;gap:8px;padding:0 12px;display:flex}.adminFilterBar select{width:100%;color:var(--ink);background:0 0;border:0;outline:0;font-weight:800}.adminFilterBar .outlineButton{min-height:42px}.adminSummaryStrip{flex-wrap:wrap;gap:8px;display:flex}.adminSummaryStrip span{color:var(--teal);background:#eef7f5;border-radius:8px;padding:8px 10px;font-size:13px;font-weight:900}.adminTable{border:1px solid var(--line);background:#fff;border-radius:8px;width:100%;display:grid;overflow:hidden}.adminTableHead{color:var(--muted);text-transform:uppercase;background:#edf5f3;grid-template-columns:minmax(150px,1.35fr) minmax(86px,.7fr) minmax(86px,.7fr) minmax(92px,.75fr);align-items:center;gap:10px;padding:9px 10px;font-size:11px;font-weight:950;display:grid}.adminTableRow{background:#fff;grid-template-columns:minmax(150px,1.35fr) minmax(86px,.7fr) minmax(86px,.7fr) minmax(92px,.75fr);align-items:center;gap:10px;min-height:54px;padding:8px 10px;display:grid}.adminTableRow+.adminTableRow{border-top:1px solid var(--line)}.adminTableRow strong,.adminTableRow span{text-overflow:ellipsis;overflow:hidden}.adminPersonCell{grid-template-columns:28px 1fr;align-items:center;gap:7px;min-width:0;display:grid}.adminPersonCell strong,.adminPersonCell span{display:block}.adminPersonCell span{color:var(--muted);margin-top:1px;font-size:11px}.adminPersonCell strong{font-size:13px;line-height:1.1}.adminTableRow>span{color:var(--ink);text-align:center;white-space:nowrap;font-size:12px;font-weight:900}.adminTableRow>div:last-child{justify-self:stretch}.adminTableRow .pill{white-space:nowrap;justify-content:center;width:100%;min-width:0;padding:6px 7px;font-size:11px}.historyFilter{max-width:360px}.historyControls{grid-template-columns:1fr 1fr;align-items:end;gap:10px;display:grid}.historyControls .outlineButton{grid-column:1/-1;width:100%;min-height:48px;padding:0 14px}.adminHistoryList{gap:12px;display:grid}.historyDateGroup{gap:8px;display:grid}.historyDateGroup h3{color:var(--teal);text-transform:capitalize;margin:0;font-size:13px;font-weight:950}.historyRow{border:1px solid var(--line);background:var(--soft);border-radius:8px;grid-template-columns:auto 1fr auto;align-items:center;gap:10px;padding:12px;display:grid}.historyRow strong,.historyRow span{display:block}.historyRow span{color:var(--muted);font-size:13px}.historyRow>span:last-child{color:var(--teal);background:#fff;border-radius:8px;grid-column:2/4;justify-self:start;padding:5px 8px;font-weight:900}@media (max-width:980px){.adminGrid,.adminGrid.overview,.adminGrid.usersGrid,.adminTopbar{grid-template-columns:1fr}.adminTabs{grid-template-columns:repeat(2,1fr)}.adminFilterBar,.historyControls{grid-template-columns:1fr}.historyRow{grid-template-columns:auto 1fr auto}.adminUserRow{grid-template-columns:auto 1fr}.adminIconActions{grid-column:1/-1}}@media (max-width:430px){.adminTableHead,.adminTableRow{grid-template-columns:minmax(108px,1.2fr) minmax(58px,.65fr) minmax(58px,.65fr) minmax(72px,.75fr);gap:5px;padding-left:8px;padding-right:8px}.adminTableHead{font-size:10px}.adminPersonCell{grid-template-columns:24px 1fr;gap:6px}.adminAvatar.small{width:24px;height:24px;font-size:10px}.adminPersonCell strong,.adminTableRow>span{font-size:11px}.adminPersonCell span{font-size:10px}.adminTableRow .pill{padding:5px 4px;font-size:10px}}@media (max-width:900px){.mockupStage{grid-template-columns:1fr;padding:18px}.storyPanel{text-align:center;justify-items:center}.screenPicker{grid-template-columns:repeat(2,minmax(0,1fr))}.phoneFrame{min-height:780px}}@media (max-width:600px){html,body{background:#fbfcfb}.mockupStage{background:#fbfcfb;gap:0;min-height:100dvh;padding:0;display:block}.storyPanel{display:none}.phoneFrame{width:100%;max-width:none;height:100dvh;min-height:100dvh;box-shadow:none;background:#fbfcfb;border-radius:0;padding:0}.phoneScreen{border:0;border-radius:0;height:100dvh}.statusBar{display:none}.appHeader{height:calc(72px + env(safe-area-inset-top));padding:env(safe-area-inset-top) 18px 0}.appHeader h1{font-size:23px}.content{height:calc(100dvh - 72px - env(safe-area-inset-top) - 86px - env(safe-area-inset-bottom));padding:18px 18px calc(18px + env(safe-area-inset-bottom))}.loginContent{height:calc(100dvh - 72px - env(safe-area-inset-top) - env(safe-area-inset-bottom));overflow:hidden}.content.resultContent{height:calc(100dvh - 86px - env(safe-area-inset-bottom))}.verifyContent{height:calc(100dvh - 72px - env(safe-area-inset-top));grid-template-rows:auto auto minmax(300px,1fr) auto;padding-top:6px;display:grid;overflow:hidden}.bottomNav{height:calc(86px + env(safe-area-inset-bottom));padding-bottom:calc(12px + env(safe-area-inset-bottom))}.phoneFrame,.phoneScreen,.content,.verifyContent{overflow-x:hidden}.heroStatus h2,.resultContent h1{font-size:30px}.employeeProfileHero{gap:12px;padding:12px}.profileBrandStrip .brandLogo{width:138px}.avatar.large{border-radius:16px;width:60px;height:60px;font-size:17px}.profileIdentity{gap:10px}.profileIdentity h2{font-size:21px}.profileStatusGrid{gap:8px;margin-top:10px}.profileStat{min-height:62px;padding:9px 10px}.profileStat strong{font-size:15px}.cameraMock{height:auto;min-height:0}.steps{padding:0 18px}.steps span{width:46px;height:46px;font-size:18px}.stepLabel{margin:5px 0 7px;font-size:15px}.faceOval{width:min(68vw,250px);height:min(42dvh,310px)}.motionGuide{gap:6px;width:94px;min-height:104px;padding:8px;bottom:10px;right:10px}.motionHead{width:44px;height:52px}.motionEye{top:20px}.motionEye.left{left:13px}.motionEye.right{right:13px}.motionMouth{width:14px;bottom:14px;left:15px}.motionSignal{font-size:10px}.motionGuide.turn_left:after,.motionGuide.turn_right:after,.motionGuide.move_closer:after{width:22px;height:22px}.captureCue strong{font-size:clamp(30px,9vw,58px)}.captureCue small{font-size:15px}.cameraMock .pill{padding:7px 10px;font-size:12px;top:12px;left:12px}.corner{width:34px;height:34px}.topLeft{top:70px;left:18px}.topRight{top:70px;right:18px}.bottomLeft{bottom:26px;left:18px}.bottomRight{bottom:26px;right:18px}.challengePanel{padding:8px 12px calc(10px + env(safe-area-inset-bottom));border-top:1px solid var(--line);background:#fff;gap:7px}.challengePanel>.pill{display:none}.challengeInstruction{grid-template-columns:40px 1fr;gap:9px;padding:9px}.challengeInstruction h2{font-size:19px}.challengeInstruction p{font-size:12px;line-height:1.25}.arrowBadge{border-radius:12px;width:40px;height:40px}.checkGrid span{gap:4px;min-height:32px;padding:4px;font-size:9px}.smallLocation,.captureState,.inlineError{font-size:12px}.smallLocation{display:none}.challengePanel .primaryButton,.challengePanel .outlineButton{min-height:43px}}.adminShell{width:min(100%,760px);min-height:100dvh;color:var(--ink);background:#fff;margin:0 auto;padding:34px 28px 28px}.adminLogin{width:100%;min-height:calc(100dvh - 62px);box-shadow:none;border:0;align-content:start;margin:0;padding:78px 24px 28px}.adminLoginShell{overflow:hidden}.adminLoginHeader{background:#fff;grid-template-columns:auto 1fr auto;align-items:center;gap:14px;height:74px;padding:0 0 10px;display:grid}.adminLoginHeader .iconButton{color:var(--teal);background:#f7fbfa;border:1px solid #e5eeeb}.adminLoginHeader h1,.adminLoginHeader span{margin:0}.adminLoginHeader h1{color:var(--ink);font-size:25px;line-height:1.1}.adminLoginHeader span{color:var(--muted);font-size:12px;font-weight:800;display:block}.adminLoginHero{text-align:center;justify-items:center;gap:18px;margin-bottom:46px;display:grid}.adminLoginHero .brandLogo{width:min(56vw,260px);height:auto}.adminLoginHero h1{color:var(--teal);font-size:clamp(34px,7vw,44px);line-height:1.04}.adminLoginHero p{max-width:420px;color:var(--muted);font-size:21px;line-height:1.45}.adminPasswordBox{background:#fff;border:1px solid #b8c5cb;border-radius:8px;grid-template-columns:1fr auto;align-items:center;gap:12px;min-height:58px;padding:0 16px;display:grid}.adminPasswordBox input{border:0;outline:0;min-height:56px;padding:0}.adminPasswordBox svg{color:var(--muted)}.adminLoginFooter{color:var(--muted);border-top:1px solid var(--line);grid-template-columns:auto 1fr;align-items:center;gap:3px 12px;margin-top:auto;padding-top:28px;display:grid}.adminLoginFooter svg{color:var(--muted);grid-row:span 2}.adminLoginFooter span,.adminLoginFooter small{display:block}.adminTopbar{border:0;border-bottom:1px solid var(--line);max-width:none;box-shadow:none;border-radius:0;grid-template-columns:1fr auto;gap:16px;margin:0;padding:12px 0 22px}.adminBrandTitle{grid-template-columns:118px 1fr;align-items:center;gap:14px;display:grid}.adminBrandTitle .brandLogo{width:118px;height:auto}.adminBrandTitle h1{color:var(--ink);margin:0;font-size:24px;line-height:1.05}.adminBrandTitle span{color:var(--muted);margin-top:3px;font-size:13px;display:block}.adminTopActions{grid-column:auto;justify-content:end}.adminTopActions .outlineButton{border-color:var(--line);width:auto;min-height:44px;padding:0 14px}.adminTabs{border-bottom:1px solid var(--line);grid-template-columns:repeat(5,minmax(0,1fr));gap:0;max-width:none;margin:0 -28px 28px;padding:0 28px;display:grid;overflow:visible}.adminTabs button{min-height:86px;color:var(--muted);background:0 0;border:0;border-radius:0;align-content:center;justify-items:center;gap:7px;padding:0 4px;font-size:13px;display:grid;position:relative}.adminTabs button.active{color:var(--teal);background:0 0}.adminTabs button.active:after{content:"";background:var(--teal);border-radius:999px 999px 0 0;height:4px;position:absolute;bottom:0;left:18%;right:18%}.adminPanelStack{gap:22px;display:grid}.adminPageTitle h2{color:#081723;letter-spacing:0;margin:0;font-size:clamp(34px,7vw,44px);line-height:1.05}.adminPageTitle p{color:var(--muted);margin:8px 0 0;font-size:20px;line-height:1.35}.adminCard,.adminCard.wide{border:1px solid #dce5e8;border-radius:8px;width:100%;max-width:none;padding:24px;box-shadow:0 10px 26px #1018200d}.adminKpiGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:18px}.adminKpiGrid .metric{background:#fff;align-content:space-between;min-height:170px;padding:20px;box-shadow:0 8px 18px #1018200a}.adminSearchRow{grid-template-columns:1fr 132px;align-items:end;gap:18px;display:grid}.adminSearchRow .outlineButton{border-color:var(--line);min-height:58px}.adminUserTable,.adminTable,.adminHistoryList{background:#fff;border:1px solid #dce5e8;border-radius:8px;overflow:hidden}.adminUserTableHead,.adminUserRow{grid-template-columns:minmax(190px,1.55fr) minmax(112px,.8fr) minmax(122px,.9fr) minmax(94px,.72fr) minmax(86px,.62fr);align-items:center;gap:12px;display:grid}.adminUserTableHead{min-height:56px;color:var(--muted);border-bottom:1px solid var(--line);background:#fbfcfc;padding:0 18px;font-size:13px;font-weight:900}.adminUserRow{background:#fff;border:0;border-radius:0;min-height:96px;padding:14px 18px}.adminUserRow+.adminUserRow{border-top:1px solid var(--line)}.adminUserPerson,.adminPersonCell{grid-template-columns:52px minmax(0,1fr);align-items:center;gap:12px;min-width:0;display:grid}.adminUserPerson .adminAvatar,.adminPersonCell .adminAvatar{border-radius:8px;width:52px;height:52px}.adminUserPerson strong,.adminPersonCell strong{font-size:18px;line-height:1.1}.adminUserPerson span,.adminPersonCell span{color:var(--muted);margin-top:4px;font-size:14px}.adminUserRow>span{color:var(--muted);line-height:1.25}.adminIconActions{grid-column:auto;justify-content:end}.adminFilterBar{grid-template-columns:minmax(0,1fr) minmax(0,1fr) 150px;gap:14px}.adminFilterBar label,.adminFilterBar .outlineButton{background:#fff;min-height:58px}.adminSummaryStrip{background:#fff;border:1px solid #dce5e8;border-radius:8px;grid-template-columns:repeat(3,1fr);gap:0;padding:18px;display:grid}.adminSummaryStrip span{color:var(--ink);background:0 0;justify-items:center;gap:4px;padding:0;font-size:17px;font-weight:800;display:grid}.adminSummaryStrip span+span{border-left:1px solid var(--line)}.adminSummaryStrip strong{color:var(--teal);font-size:32px;line-height:1}.adminTableHead,.adminTableRow{grid-template-columns:minmax(220px,1.65fr) minmax(82px,.65fr) minmax(82px,.65fr) minmax(130px,.8fr);gap:14px}.adminTableHead{text-transform:none;background:#fbfcfc;min-height:56px;padding:0 18px;font-size:16px}.adminTableRow{min-height:116px;padding:16px 18px}.adminTableRow>span{color:var(--teal);font-size:22px}.adminTableRow .pill{min-height:42px;font-size:15px}.enrollmentCard .fieldGroup,.enrollEmployeeSummary,.adminCamera,.enrollProgress,.enrollSavedPhotos,.enrollmentCard .adminActions,.enrollmentCard>.outlineButton,.enrollmentCard>.inlineError,.enrollmentCard>.successText{width:100%}.enrollEmployeeSummary{background:#fff}.enrollInstruction{z-index:4;border:0;border-top:1px solid var(--line);background:#fffffff5;border-radius:8px 8px 0 0;min-height:116px;padding:22px 28px;position:absolute;bottom:0;left:0;right:0}.enrollInstruction strong{font-size:22px}.enrollProgress{grid-template-columns:repeat(5,minmax(0,1fr));gap:10px}.enrollProgress span{border:1px solid var(--line);background:#fff;min-height:96px;padding:10px 8px}.enrollSavedPhotos{border:1px solid var(--line);background:#fff;border-radius:8px;gap:10px;padding:12px;display:grid}.enrollSavedPhotosHeader{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:10px;display:grid}.enrollSavedPhotosHeader small,.enrollSavedPhotosHeader strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.enrollSavedPhotosHeader small{color:var(--muted);text-transform:uppercase;font-size:12px;font-weight:950}.enrollSavedPhotosHeader strong{color:var(--ink);font-size:15px}.enrollPhotoStrip{grid-template-columns:repeat(5,minmax(0,1fr));gap:7px;display:grid}.enrollPhotoStrip figure{border:1px solid var(--line);background:var(--soft);border-radius:8px;min-width:0;margin:0;overflow:hidden}.enrollPhotoStrip img{aspect-ratio:1;object-fit:cover;width:100%;display:block}.enrollPhotoStrip figcaption{color:var(--teal);text-align:center;text-overflow:ellipsis;white-space:nowrap;padding:5px 4px;font-size:10px;font-weight:950;overflow:hidden}.enrollPhotoState{min-height:52px;color:var(--muted);text-align:center;justify-content:center;align-items:center;gap:8px;margin:0;padding:8px;font-size:12px;font-weight:800;line-height:1.3;display:flex}.adminActions{grid-template-columns:1fr}.historyControls{grid-template-columns:repeat(3,minmax(0,1fr))}.historyControls .searchField{grid-column:span 2}.historyControls .outlineButton{grid-column:auto}.historyDateGroup{gap:0}.historyDateGroup+.historyDateGroup{border-top:18px solid #fff}.historyDateGroup h3{min-height:58px;color:var(--ink);border-bottom:1px solid var(--line);align-items:center;padding:0 20px;font-size:19px;display:flex}.historyRow{background:#fff;border:0;border-radius:0;grid-template-columns:minmax(210px,1.35fr) minmax(110px,.7fr) minmax(120px,.75fr) minmax(150px,.85fr);gap:16px;min-height:88px;padding:14px 18px}.historyRow+.historyRow{border-top:1px solid var(--line)}.historyRow>.adminAvatar{display:none}.historyEventCell,.historyConfidence,.historyLocation{align-content:center;gap:4px;display:grid}.historyConfidence strong{color:var(--green);font-size:20px}.historyLocation{grid-template-columns:auto 1fr}.historyLocation small{color:var(--muted);grid-column:2}@media (max-width:720px){.adminShell{width:100%;padding:24px 18px}.adminBrandTitle{grid-template-columns:106px 1fr}.adminBrandTitle .brandLogo{width:106px}.adminBrandTitle h1{font-size:20px}.adminTopActions{justify-content:end}.adminTopActions .pill{min-height:32px;padding:0 9px;font-size:12px}.adminTopActions .outlineButton{min-height:38px;padding:0 10px}.adminTabs{margin-left:-18px;margin-right:-18px;padding-left:18px;padding-right:18px}.adminSearchRow,.historyControls{grid-template-columns:1fr}.historyControls .searchField,.historyControls .outlineButton{grid-column:auto}}@media (max-width:520px){.adminShell{padding:20px 12px}.adminBrandTitle{grid-template-columns:92px 1fr;gap:9px}.adminBrandTitle .brandLogo{width:92px}.adminTopbar{grid-template-columns:1fr}.adminTopActions{justify-content:space-between}.adminTabs{margin-left:-12px;margin-right:-12px;padding-left:12px;padding-right:12px}.adminTabs button{min-height:72px;font-size:11px}.adminCard,.adminCard.wide{padding:14px}.adminPageTitle h2{font-size:34px}.adminPageTitle p{font-size:18px}.adminKpiGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:9px}.adminKpiGrid .metric{min-height:118px;padding:12px}.adminKpiGrid .metric span{font-size:13px}.adminKpiGrid .metric strong{font-size:32px}.adminFilterBar{grid-template-columns:1fr}.adminUserTable{overflow-x:auto}.adminUserTableHead,.adminUserRow{min-width:680px}.adminTableHead,.adminTableRow{grid-template-columns:minmax(140px,1.4fr) minmax(64px,.65fr) minmax(64px,.65fr) minmax(88px,.8fr);gap:7px;padding-left:10px;padding-right:10px}.adminTableHead{font-size:12px}.adminTableRow{min-height:72px}.adminPersonCell{grid-template-columns:32px minmax(0,1fr);gap:7px}.adminPersonCell .adminAvatar{width:32px;height:32px}.adminPersonCell strong{font-size:13px}.adminPersonCell span{font-size:11px}.adminTableRow>span{font-size:13px}.adminTableRow .pill{min-height:32px;font-size:10px}.adminSummaryStrip strong{font-size:28px}.historyRow{grid-template-columns:1fr auto}.historyConfidence,.historyLocation{grid-column:1/-1}}.adminMockupStage .phoneScreen>.adminShell{overscroll-behavior:contain;width:100%;height:calc(100% - 58px);min-height:0;overflow-y:auto}.adminMockupStage .phoneScreen>.adminLoginShell{grid-template-rows:auto minmax(0,1fr);padding-top:0;display:grid;overflow:hidden}.adminMockupStage .phoneScreen>.adminLoginShell .adminLoginHeader{padding:0 0 6px}.adminMockupStage .phoneScreen>.adminShell .adminLogin{min-height:0;margin-top:0;padding:16px 10px 14px;overflow:hidden}.adminMockupStage .phoneScreen>.adminShell .adminLoginHero{gap:12px;margin-bottom:18px}.adminMockupStage .phoneScreen>.adminShell .adminLoginHero .brandLogo{width:min(68vw,230px)}.adminMockupStage .phoneScreen>.adminShell .adminLoginHero h1{font-size:clamp(30px,7vw,38px)}.adminMockupStage .phoneScreen>.adminShell .adminLoginHero p{font-size:16px}.adminMockupStage .phoneScreen>.adminShell .adminLoginFooter{margin-top:16px;padding-top:14px}.adminMockupStage .phoneScreen>.adminShell .adminTopbar{z-index:5;background:linear-gradient(#f4f7f5 0%,#f4f7f5f0 100%);position:sticky;top:0}.adminStoryActions{gap:12px;width:min(100%,520px);display:grid}@media (max-width:600px){.adminMockupStage .phoneScreen>.adminShell{height:100dvh}}html,body{overflow-x:hidden}.adminShell,.adminShell *,.adminCard,.adminUserTable,.adminTable,.adminHistoryList{box-sizing:border-box}.adminShell{width:min(100%,760px);max-width:100%;padding:14px 16px 18px;overflow-x:hidden}.adminTopbar,.adminTabs,.adminPanelStack,.adminCard,.adminCard.wide,.adminUserTable,.adminTable,.adminHistoryList{min-width:0;max-width:100%}.adminTopbar{padding:8px 0 12px}.adminBrandTitle,.adminTopActions,.adminTabs button,.adminUserPerson,.adminPersonCell,.historyRow>div{min-width:0}.adminTabs{min-height:0;margin-bottom:14px}.adminTabs button{min-height:58px;font-size:11px}.adminPageTitle h2{font-size:clamp(26px,5.6vw,31px);line-height:1.08}.adminPageTitle p{font-size:15px}.adminCard,.adminCard.wide{padding:12px}.adminKpiGrid .metric{min-height:92px;padding:10px}.adminKpiGrid .metric span{font-size:12px}.adminKpiGrid .metric strong{font-size:28px}.fieldGroup input,.fieldGroup select,.adminSearchRow .outlineButton,.adminFilterBar label,.adminFilterBar .outlineButton{min-height:44px;font-size:13px}.adminSearchRow{grid-template-columns:minmax(0,1fr) minmax(96px,112px);gap:10px}.adminUserTable{overflow:hidden}.adminUserTableHead,.adminUserRow{grid-template-columns:minmax(140px,1.35fr) minmax(76px,.7fr) minmax(90px,.8fr) minmax(72px,.62fr) minmax(62px,.5fr);gap:8px;min-width:0!important}.adminUserTableHead{min-height:40px;padding:0 10px;font-size:11px}.adminUserRow{min-height:64px;padding:8px 10px}.adminUserRow>span,.adminUserPerson strong,.adminUserPerson span,.adminPersonCell strong,.adminPersonCell span,.historyRow strong,.historyRow span{text-overflow:ellipsis;min-width:0;overflow:hidden}.adminUserPerson,.adminPersonCell{grid-template-columns:32px minmax(0,1fr);gap:7px}.adminUserPerson .adminAvatar,.adminPersonCell .adminAvatar{width:32px;height:32px;font-size:10px}.adminUserPerson strong,.adminPersonCell strong{font-size:14px}.adminUserPerson span,.adminPersonCell span,.adminUserRow>span{font-size:11px}.adminIconActions{gap:4px}.adminIconActions button{width:30px;height:30px}.adminSummaryStrip{padding:10px}.adminSummaryStrip strong{font-size:26px}.adminTableHead,.adminTableRow{grid-template-columns:minmax(118px,1.25fr) minmax(58px,.6fr) minmax(58px,.6fr) minmax(78px,.78fr);gap:6px;padding-left:8px;padding-right:8px}.adminTableHead{min-height:38px;font-size:11px}.adminTableRow{min-height:60px;padding-top:7px;padding-bottom:7px}.adminTableRow>span{font-size:12px}.adminTableRow .pill{min-height:28px;padding:4px 5px;font-size:10px}.adminCamera{height:clamp(330px,48dvh,460px)}.adminCaptureOverlay{z-index:40;background:#fff;grid-template-rows:auto minmax(0,1fr) auto;display:grid;position:absolute;inset:0;overflow:hidden}.adminCaptureTopbar{border-bottom:1px solid var(--line);background:#fff;grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;min-height:74px;padding:10px 14px;display:grid}.adminCaptureTopbar .iconButton{color:var(--teal);background:#f7fbfa;border:1px solid #e5eeeb}.adminCaptureTopbar span,.adminCaptureTopbar strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.adminCaptureTopbar span{color:var(--muted);font-size:12px;font-weight:900}.adminCaptureTopbar strong{color:var(--ink);font-size:17px}.adminCaptureCamera{background:#142022;place-items:center;min-height:0;display:grid;position:relative;overflow:hidden}.adminCaptureCamera video{object-fit:cover;width:100%;height:100%;position:absolute;inset:0;transform:scaleX(-1)}.adminCaptureCamera .adminFaceGuide{width:min(68vw,270px);height:min(88vw,350px)}.adminCaptureInstruction{border-top:1px solid var(--line);background:#fff;gap:10px;padding:14px;display:grid}.adminCaptureInstruction small{color:var(--teal);text-transform:uppercase;font-weight:950}.adminCaptureInstruction strong{color:var(--ink);font-size:17px;line-height:1.2}.enrollProgress.compact{grid-template-columns:repeat(5,34px);justify-content:center;gap:8px}.enrollProgress.compact span{border-radius:50%;width:34px;min-height:34px;padding:0;font-size:12px}.adminCaptureInstruction .adminActions{grid-template-columns:minmax(0,1fr) minmax(96px,.55fr);gap:8px}.adminEnrollmentGallery{z-index:45;background:#1018206b;place-items:stretch stretch;display:grid;position:absolute;inset:0;overflow:hidden}.usersGrid{position:relative}.adminGalleryPanel{background:#fff;grid-template-rows:auto minmax(0,1fr);min-height:0;display:grid;overflow:hidden}.adminGalleryHeader{border-bottom:1px solid var(--line);grid-template-columns:auto minmax(0,1fr) auto;align-items:center;gap:12px;min-height:74px;padding:10px 14px;display:grid}.adminGalleryHeader .iconButton{color:var(--teal);background:#f7fbfa;border:1px solid #e5eeeb}.adminGalleryHeader span,.adminGalleryHeader strong{text-overflow:ellipsis;white-space:nowrap;min-width:0;display:block;overflow:hidden}.adminGalleryHeader span{color:var(--muted);font-size:12px;font-weight:900}.adminGalleryHeader strong{color:var(--ink);font-size:17px}.adminGalleryGrid{grid-template-columns:1fr;gap:10px;min-height:0;padding:14px;display:grid;overflow:auto}.adminGalleryGrid figure{border:1px solid var(--line);background:#fff;border-radius:8px;margin:0;overflow:hidden}.adminGalleryGrid img{aspect-ratio:4/3;object-fit:cover;width:100%;display:block}.adminGalleryGrid figcaption{color:var(--muted);justify-content:space-between;gap:10px;padding:9px 10px;font-size:12px;font-weight:800;display:flex}.adminGalleryGrid figcaption strong{color:var(--teal)}.adminGalleryState{min-height:260px;color:var(--muted);text-align:center;align-content:center;place-items:center;gap:10px;padding:22px;font-weight:900;display:grid}.enrollProgress span{min-height:60px;padding:8px 4px;font-size:10px}.historyControls{gap:10px}.historyDateGroup h3{min-height:40px;padding:0 12px;font-size:15px}.historyRow{gap:8px;min-height:64px;padding:8px 10px}.historyRow strong{font-size:14px}.historyRow span,.historyLocation small{font-size:11px}.historyConfidence strong{font-size:16px}@media (max-width:640px){.adminShell{padding:12px 10px 16px}.adminTopbar{grid-template-columns:1fr auto;align-items:center}.adminBrandTitle{grid-template-columns:78px minmax(0,1fr);gap:8px}.adminBrandTitle .brandLogo{width:78px}.adminBrandTitle h1{font-size:16px}.adminBrandTitle span,.adminTopActions .pill{display:none}.adminTopActions .outlineButton{min-height:34px;padding:0 9px;font-size:12px}.adminTabs{margin-left:-10px;margin-right:-10px;padding-left:10px;padding-right:10px}.adminTabs button{min-height:54px;font-size:10px}.adminPanelStack{gap:12px}.adminCard,.adminCard.wide{padding:10px}.adminSearchRow,.adminFilterBar,.historyControls{grid-template-columns:1fr}.adminUserTableHead{display:none}.adminUserRow{grid-template-columns:minmax(0,1fr) auto;gap:6px 8px;min-height:68px}.adminUserPerson{grid-column:1}.adminUserRow>span{white-space:normal;grid-column:1/-1}.adminUserRow>span:first-of-type:before{content:"Rol: ";color:var(--muted);font-weight:900}.adminUserRow>span:nth-of-type(2):before{content:"Última asistencia: ";color:var(--muted);font-weight:900}.adminUserRow .pill{white-space:nowrap;grid-area:1/2;align-self:center}.adminIconActions{grid-column:1/-1;justify-content:end}.adminTableHead,.adminTableRow{grid-template-columns:minmax(104px,1.2fr) minmax(52px,.55fr) minmax(52px,.55fr) minmax(68px,.7fr);gap:4px;padding-left:6px;padding-right:6px}.adminTableHead{min-height:34px;font-size:10px}.adminTableRow{min-height:56px}.adminPersonCell{grid-template-columns:26px minmax(0,1fr);gap:5px}.adminPersonCell .adminAvatar{width:26px;height:26px;font-size:9px}.adminPersonCell strong,.adminTableRow>span{font-size:11px}.adminPersonCell span,.adminTableRow .pill{font-size:9px}.historyRow{grid-template-columns:1fr auto}.historyEventCell{justify-items:end}.historyConfidence,.historyLocation{grid-column:1/-1}}
