:root{--canvas:#f6f9fb;--page:#f6f9fb;--ink:#052b4c;--muted:#657583;--soft:#8799a7;--line:#052b4c21;--line-strong:#052b4c38;--green:#0b56a2;--yellow:#0fd1e8;--danger:#c45151;--cyan:#12a8c7;--navy:#082f52;--deep:#061b2d;--display-serif:"Songti SC", "STSong", "Noto Serif SC", "Source Han Serif SC", serif;--mono:"SFMono-Regular", Consolas, "Liberation Mono", Menlo, monospace;color:var(--ink);background:var(--page);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;letter-spacing:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}*{box-sizing:border-box}html{background:#f6f9fb;min-width:320px}body{background:linear-gradient(#f8fbfc 0%,#fff 42%,#f4f8fb 100%);min-width:320px;min-height:100vh;margin:0;position:relative}body:before{z-index:-1;pointer-events:none;content:"";background-color:#0000;background-image:linear-gradient(#052b4c07 1px,#0000 1px),linear-gradient(90deg,#052b4c07 1px,#0000 1px);background-position:0 0,0 0;background-repeat:repeat,repeat;background-size:76px 76px;background-attachment:scroll,scroll;background-origin:padding-box,padding-box;background-clip:border-box,border-box;position:fixed;inset:0;-webkit-mask-image:linear-gradient(#000000b8,#0000 76%);mask-image:linear-gradient(#000000b8,#0000 76%)}button{letter-spacing:0}:focus-visible{outline-offset:2px;outline:3px solid #12a8c747}#root{min-height:100vh}button,input,select{font:inherit}button{color:inherit}.app-shell{background:var(--canvas);min-height:100vh;color:var(--ink)}.sidebar{z-index:40;color:#eef2ef;background:#141a1b;border-right:1px solid #293031;flex-direction:column;width:236px;padding:22px 16px 16px;display:flex;position:fixed;inset:0 auto 0 0}.brand-row{align-items:center;gap:11px;min-height:44px;padding:0 4px;display:flex}.brand-mark{color:#161a1a;background:#e8f7fb;border:1px solid #bfeaf2;border-radius:7px;flex:0 0 40px;place-items:center;width:40px;height:40px;display:grid}.brand-row>div:not(.brand-mark){gap:2px;display:grid}.brand-row strong{font-size:19px;line-height:1.1}.brand-row small{color:#8e9a96;font-size:11px}.mobile-close,.menu-button,.mobile-brand{display:none}.project-switch{text-align:left;color:#eff3f0;cursor:pointer;background:#202829;border:1px solid #30393a;border-radius:7px;grid-template-columns:32px 1fr 16px;align-items:center;gap:9px;width:100%;margin:25px 0 28px;padding:11px 10px;display:grid}.project-switch>span:nth-child(2){gap:3px;min-width:0;display:grid}.project-switch strong{text-overflow:ellipsis;white-space:nowrap;font-size:13px;overflow:hidden}.project-switch small{color:#8f9b97;font-size:11px}.project-icon{width:32px;height:32px;color:var(--yellow);background:#193241;border-radius:6px;place-items:center;display:grid}.nav-list{gap:5px;display:grid}.nav-label{color:#71807b;text-transform:uppercase;margin:0 10px 7px;font-size:10px;font-weight:700}.nav-item{color:#aeb8b4;text-align:left;cursor:pointer;background:0 0;border:0;border-radius:6px;grid-template-columns:20px 1fr auto;align-items:center;gap:10px;min-height:43px;padding:0 11px;transition:background .16s,color .16s;display:grid}.nav-item.active{color:#fff;background:var(--yellow);box-shadow:inset 3px 0 #8be4f1}.nav-item b{color:#fff;background:var(--danger);border-radius:10px;place-items:center;min-width:20px;height:20px;padding:0 5px;font-size:11px;display:grid}.site-health{background:#1b2324;border:1px solid #2b3435;border-radius:7px;margin-top:auto;padding:14px}.site-health-head,.site-health-head span,.device-grid,.site-health button{align-items:center;display:flex}.site-health-head{justify-content:space-between;gap:8px;font-size:11px}.site-health-head span{color:#b7c0bd;gap:6px}.site-health-head strong{color:#60d0a2;font-size:10px}.device-grid{gap:8px;margin:13px 0}.device-grid span{color:#8f9b97;background:#252e2f;border-radius:4px;flex:1;padding:8px;font-size:10px}.device-grid b{color:#f0f3f1;margin-top:2px;font-size:13px;display:block}.site-health button{color:var(--yellow);cursor:pointer;background:0 0;border:0;gap:5px;padding:0;font-size:11px}.admin-mini{border-top:1px solid #293132;grid-template-columns:32px 1fr 17px;align-items:center;gap:9px;margin-top:13px;padding:10px 7px 0;display:grid}.admin-avatar,.person-cell>span,.large-avatar{place-items:center;font-weight:700;display:grid}.admin-avatar{color:#25302d;background:#d9e5de;border-radius:5px;width:32px;height:32px}.admin-mini>span:nth-child(2){gap:2px;display:grid}.admin-mini strong{font-size:11px}.admin-mini small{color:#788580;font-size:10px}.workspace{min-width:0;margin-left:236px}.topbar{z-index:30;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff5;justify-content:space-between;align-items:center;gap:24px;height:66px;padding:0 30px;display:flex;position:sticky;top:0}.breadcrumb,.top-actions,.global-search,.heading-line,.page-actions,.primary-button,.secondary-button,.filter-button,.selection-bar,.selection-bar>div,.surface-head,.surface-head button,.attention-strip,.chart-summary,.chart-legend,.kpi-top,.mode-card,.preview-actions,.security-note,.batch-row,.result-pill,.handled,.pending,.date-control,.privacy-tip{align-items:center;display:flex}.breadcrumb{color:var(--muted);gap:7px;font-size:12px}.breadcrumb strong{color:var(--ink)}.top-actions{gap:10px}.global-search{color:#86908d;background:#f4f6f5;border:1px solid #0000;border-radius:5px;gap:8px;width:230px;height:36px;padding:0 11px}.global-search:focus-within{color:var(--green);background:#fff;border-color:#9ac9b6;box-shadow:0 0 0 3px #16825d17}.global-search input{width:100%;min-width:0;color:var(--ink);background:0 0;border:0;outline:0;font-size:12px}.global-search input::placeholder{color:#9ca5a2}.icon-button{border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:5px;place-items:center;width:36px;height:36px;display:grid}.mobile-close,.menu-button{display:none}.notice-wrap,.notice-button{position:relative}.notice-button>span{color:#fff;background:var(--danger);border:2px solid #fff;border-radius:50%;place-items:center;width:17px;height:17px;font-size:9px;display:grid;position:absolute;top:-4px;right:-4px}.notice-popover{z-index:80;border:1px solid var(--line);background:#fff;border-radius:7px;width:310px;position:absolute;top:44px;right:0;overflow:hidden;box-shadow:0 18px 45px #121d1a29}.popover-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:14px 15px;display:flex}.popover-head button,.notice-popover>button{cursor:pointer;background:0 0;border:0}.notice-popover>button{text-align:left;border-bottom:1px solid #eef1ef;grid-template-columns:20px 1fr;gap:10px;width:100%;padding:13px 15px;display:grid}.notice-popover>button:hover{background:#f8faf9}.notice-popover>button>span{gap:3px;display:grid}.notice-popover>button small{color:var(--muted)}.primary-button,.secondary-button,.filter-button{cursor:pointer;border-radius:5px;justify-content:center;gap:7px;height:36px;padding:0 13px;font-size:12px;font-weight:700}.primary-button{color:#fff;background:var(--yellow);border:1px solid #0a8fab}.primary-button:hover{background:#0b56a2}.primary-button:disabled{color:#89908d;cursor:not-allowed;background:#e6e9e7;border-color:#d9ddda}.secondary-button,.filter-button{color:#3b4743;border:1px solid var(--line-strong);background:#fff}.secondary-button:hover,.filter-button:hover{background:#f6f8f7}.compact-action{padding:0 12px}.page-wrap{width:min(100%,1540px);margin:0 auto;padding:28px 30px 44px}.page-heading{justify-content:space-between;align-items:flex-start;gap:22px;min-height:58px;margin-bottom:22px;display:flex}.heading-line{gap:10px}.page-heading h1{letter-spacing:0;margin:0;font-size:24px;line-height:1.2}.page-heading p{color:var(--muted);margin:7px 0 0;font-size:12px}.work-state{color:#126247;background:#e5f4ed;border-radius:4px;align-items:center;gap:4px;padding:4px 7px;font-size:10px;font-weight:700;display:inline-flex}.page-actions{gap:8px}.attention-strip{border:1px solid #cbeaf1;border-left:4px solid var(--cyan);background:#eef8fb;border-radius:6px;gap:12px;min-height:66px;margin-bottom:16px;padding:12px 15px}.attention-icon{color:#087f99;background:#dff4f8;border-radius:5px;flex:0 0 38px;place-items:center;width:38px;height:38px;display:grid}.attention-strip>div:nth-child(2){gap:3px;display:grid}.attention-strip strong{font-size:13px}.attention-strip span{color:#4e6470;font-size:11px}.attention-strip button{color:#5d430d;cursor:pointer;background:0 0;border:0;align-items:center;gap:5px;margin-left:auto;padding:8px 10px;font-size:11px;font-weight:700;display:flex}.kpi-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:14px;margin-bottom:14px;display:grid}.kpi-card,.surface{border:1px solid var(--line);background:#fff;border-radius:7px;box-shadow:0 1px 2px #101e1906}.kpi-card{min-height:138px;padding:16px 17px;position:relative;overflow:hidden}.kpi-card:after{content:"";background:var(--kpi-color);width:52px;height:4px;position:absolute;bottom:0;right:0}.kpi-top{color:#9ca5a2;justify-content:space-between}.kpi-icon{width:35px;height:35px;color:var(--kpi-ink);background:var(--kpi-soft);border-radius:6px;place-items:center;display:grid}.kpi-card>div:nth-child(2){justify-content:space-between;align-items:baseline;margin-top:12px;display:flex}.kpi-card>div:nth-child(2) span{color:#52605b;font-size:12px}.kpi-card>div:nth-child(2) strong{font-size:30px;line-height:1}.kpi-card>small{color:#7b8782;margin-top:7px;font-size:10px;display:block}.dashboard-grid{grid-template-columns:minmax(0,1.55fr) minmax(330px,.85fr);gap:14px;display:grid}.attendance-chart,.live-panel,.workforce-panel,.quick-panel{min-width:0;padding:18px}.surface-head{justify-content:space-between;gap:14px}.surface-head h2{letter-spacing:0;margin:0;font-size:15px}.surface-head p{color:var(--muted);margin:4px 0 0;font-size:10px}.surface-head button{color:var(--green);cursor:pointer;background:0 0;border:0;gap:2px;font-size:10px}.chart-summary{justify-content:space-between;margin:20px 0 6px}.chart-summary>div{align-items:baseline;gap:8px;display:flex}.chart-summary strong{font-size:29px}.chart-summary span{color:var(--muted);font-size:10px}.delta-up{background:#e7f5ef;border-radius:4px;padding:4px 6px;color:#147452!important}.bar-chart{border-bottom:1px solid var(--line);grid-template-columns:repeat(12,1fr);align-items:end;gap:7px;height:158px;padding-top:12px;display:grid}.bar{align-items:flex-end;height:122px;display:flex;position:relative}.bar i{background:#7bb9a2;border-radius:2px 2px 0 0;width:100%;min-height:5px}.bar span{color:#89938f;white-space:nowrap;font-size:9px;position:absolute;bottom:-21px;left:50%;transform:translate(-50%)}.chart-legend{color:#68746f;gap:17px;margin-top:31px;font-size:9px}.chart-legend span:last-child{margin-left:auto}.legend-dot{border-radius:50%;width:7px;height:7px;margin-right:5px;display:inline-block}.live-list{margin-top:12px}.live-row{border-bottom:1px solid #edf0ee;grid-template-columns:28px minmax(90px,1fr) auto 34px;align-items:center;gap:8px;min-height:50px;display:grid}.event-mark{border-radius:5px;place-items:center;width:27px;height:27px;display:grid}.event-mark.ok{color:#147653;background:#e5f4ed}.event-mark.warn{color:#9a4a4a;background:#f8e9e9}.event-mark.bad{color:#ae4035;background:#fae6e3}.live-row>div{gap:3px;display:grid}.live-row strong{font-size:11px}.live-row small,.live-row time{color:var(--muted);font-size:9px}.event-result{border-radius:4px;padding:4px 6px;font-size:9px}.event-result.ok{color:#166848;background:#edf7f2}.event-result.warn{color:#8f4444;background:#f8eaea}.event-result.bad{color:#a63f34;background:#fbecea}.team-bars{gap:16px;margin-top:22px;display:grid}.team-row{grid-template-columns:70px 1fr 38px;align-items:center;gap:10px;font-size:10px;display:grid}.team-row>div{background:#eef1ef;border-radius:4px;height:7px;overflow:hidden}.team-row i{border-radius:inherit;background:#26825f;height:100%;display:block}.team-row i.team-1{background:#d9aa28}.team-row i.team-2{background:#2b7eae}.team-row i.team-3{background:#cb6558}.team-row i.team-4{background:#7c8497}.team-row strong{text-align:right}.quick-actions{gap:8px;margin-top:16px;display:grid}.quick-actions button{text-align:left;cursor:pointer;background:#f8faf9;border:1px solid #edf0ee;border-radius:5px;grid-template-rows:auto auto;grid-template-columns:37px 1fr 16px;align-items:center;gap:2px 10px;padding:10px;display:grid}.quick-actions button:hover{border-color:#9dc8b7}.quick-actions button>span{color:#176b50;background:#e4f1eb;border-radius:5px;grid-row:1/3;place-items:center;width:37px;height:37px;display:grid}.quick-actions strong{font-size:11px}.quick-actions small{color:var(--muted);font-size:9px}.quick-actions svg:last-child{color:#9aa39f;grid-area:1/3/3}.table-surface{overflow:hidden}.table-toolbar{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;gap:16px;min-height:62px;padding:0 16px;display:flex}.filter-tabs{align-items:stretch;gap:20px;height:62px;display:flex}.filter-tabs button{color:#65716d;cursor:pointer;background:0 0;border:0;align-items:center;gap:5px;padding:0 2px;font-size:11px;display:flex;position:relative}.filter-tabs button:after{content:"";background:0 0;height:2px;position:absolute;bottom:-1px;left:0;right:0}.filter-tabs button.active{color:var(--ink);font-weight:700}.filter-tabs button span{color:#82908b;background:#edf1ef;border-radius:9px;place-items:center;min-width:19px;height:18px;padding:0 4px;font-size:9px;display:grid}.selection-bar{color:#185a46;background:#edf8f3;border-bottom:1px solid #cbe7dc;justify-content:space-between;gap:12px;min-height:46px;padding:7px 16px;font-size:11px}.selection-bar>span,.selection-bar>div{align-items:center;gap:8px;display:flex}.selection-bar button{color:#315b4f;cursor:pointer;background:#fff;border:1px solid #bcd9ce;border-radius:4px;height:30px;padding:0 10px;font-size:10px}.selection-bar .selection-primary{color:#fff;background:var(--green);border-color:var(--green);align-items:center;gap:5px;display:flex}.table-wrap{width:100%;overflow-x:auto}.data-table{border-collapse:collapse;width:100%;min-width:880px}.data-table th{color:#7d8884;text-align:left;border-bottom:1px solid var(--line);background:#fafbfa;height:42px;padding:0 13px;font-size:9px;font-weight:600}.data-table td{color:#3f4b47;border-bottom:1px solid #edf0ee;height:61px;padding:8px 13px;font-size:10px}.data-table tbody tr{cursor:pointer;transition:background .12s}.data-table td strong,.data-table td small{display:block}.data-table td small{color:#89938f;margin-top:3px;font-size:9px}.check-col{width:42px}.checkbox{cursor:pointer;display:inline-flex}.checkbox input{opacity:0;pointer-events:none;position:absolute}.checkbox>span{color:#fff;background:#fff;border:1px solid #bdc6c2;border-radius:3px;place-items:center;width:16px;height:16px;display:grid}.checkbox input:checked+span{background:var(--green);border-color:var(--green)}.checkbox input:focus-visible+span{outline-offset:2px;outline:2px solid #75b9a0}.person-cell{align-items:center;gap:9px;display:flex}.person-cell>span{color:#3b4a45;background:#e5ebe8;border:1px solid #d7dfdb;border-radius:5px;flex:0 0 34px;width:34px;height:34px;font-size:10px}.person-cell>div{min-width:0}.person-cell strong{color:var(--ink);font-size:11px}.status-pill,.safety-pill{white-space:nowrap;border-radius:4px;align-items:center;gap:5px;padding:4px 7px;font-size:9px;font-weight:600;display:inline-flex}.status-pill i{border-radius:50%;width:5px;height:5px}.status-在场{color:#176549;background:#e9f5ef}.status-在场 i{background:#27a777}.status-待入场{color:#0b607a;background:#e8f6fa}.status-待入场 i{background:#12a8c7}.status-离场{color:#65706c;background:#edf0ee}.status-离场 i{background:#8d9692}.status-异常{color:#a13f34;background:#fae8e5}.status-异常 i{background:#d05345}.safety-已培训{color:#226850;background:#edf7f2}.safety-待复训{color:#8f4444;background:#f8eaea}.safety-证件到期{color:#a43e34;background:#fbe9e7}.scan-time{font-variant-numeric:tabular-nums;color:var(--ink)!important}.row-more{cursor:pointer;background:0 0;border:0;border-radius:4px;place-items:center;width:28px;height:28px;display:grid}.row-more:hover{background:#e8eeeb}.table-footer{min-height:54px;color:var(--muted);justify-content:space-between;align-items:center;padding:0 16px;font-size:10px;display:flex}.table-footer div{gap:5px;display:flex}.table-footer button{color:#65716d;border:1px solid var(--line);background:#fff;border-radius:4px;min-width:29px;height:29px;padding:0 8px;font-size:9px}.table-footer button.active{color:#fff;background:var(--green);border-color:var(--green)}.qr-workspace{grid-template-columns:minmax(0,1fr) 370px;align-items:start;gap:14px;display:grid}.dual-code-brief{grid-template-columns:minmax(0,1fr) auto;align-items:center;gap:18px;margin-bottom:14px;padding:18px 20px;display:grid}.brief-label{width:max-content;color:var(--cyan);margin-bottom:7px;font-size:10px;font-weight:860;display:inline-flex}.dual-code-brief h2{color:var(--ink);margin:0 0 7px;font-size:22px}.dual-code-brief p{max-width:720px;color:var(--muted);margin:0;font-size:13px;line-height:1.7}.brief-metrics{grid-template-columns:repeat(3,98px);gap:8px;display:grid}.brief-metrics span{background:#eff7fab8;border:1px solid #052b4c1a;gap:3px;padding:11px;display:grid}.brief-metrics strong{color:var(--ink);font-size:13px}.brief-metrics small{color:var(--muted);font-size:10px}.issuer-panel{padding:21px}.step-heading{align-items:flex-start;gap:10px;display:flex}.step-heading>span{color:#fff;background:#26302e;border-radius:4px;flex:0 0 27px;place-items:center;width:27px;height:27px;font-size:9px;font-weight:700;display:grid}.step-heading>div{flex:1}.step-heading h2{margin:1px 0 4px;font-size:14px}.step-heading p{color:var(--muted);margin:0;font-size:10px}.step-heading>button{color:var(--green);cursor:pointer;background:0 0;border:0;font-size:10px}.selected-people{background:#f7f9f8;border:1px solid #e8ecea;border-radius:5px;flex-wrap:wrap;align-items:center;gap:7px;min-height:76px;margin:15px 0 0 37px;padding:10px;display:flex}.person-token{text-align:left;cursor:pointer;background:#fff;border:1px solid #dce3df;border-radius:4px;grid-template-columns:29px 1fr 14px;align-items:center;gap:7px;min-width:146px;padding:6px;display:grid}.person-token.active{border-color:#5fac91;box-shadow:inset 0 0 0 1px #5fac91}.person-token>span:first-child{color:#4b5853;background:#e7ece9;border-radius:3px;place-items:center;width:29px;height:29px;font-size:9px;font-weight:700;display:grid}.person-token>span:nth-child(2){gap:2px;display:grid}.person-token strong{font-size:10px}.person-token small{color:var(--muted);font-size:8px}.person-token>svg{color:#9ca5a1}.more-people{color:var(--green);font-size:10px;font-weight:700}.empty-select{color:var(--green);cursor:pointer;background:0 0;border:0;align-items:center;gap:5px;display:flex}.gate-code-list{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin:15px 0 0 37px;display:grid}.gate-code{text-align:left;cursor:pointer;background:#fff;border:1px solid #dce2df;border-radius:5px;grid-template-columns:36px 1fr 42px;align-items:center;gap:9px;min-height:68px;padding:9px;display:grid}.gate-code.active{border-color:var(--cyan);box-shadow:inset 0 0 0 1px var(--cyan);background:#ecf8fbd1}.gate-code>span{color:#087f99;background:#eaf5f8;place-items:center;width:36px;height:36px;display:grid}.gate-code div{gap:4px;display:grid}.gate-code strong{color:var(--ink);font-size:11px}.gate-code small{color:var(--muted);font-size:9px}.gate-code em{color:var(--cyan);text-align:right;font-size:11px;font-style:normal;font-weight:850}.step-divider{background:var(--line);height:1px;margin:21px 0}.mode-cards{grid-template-columns:repeat(2,minmax(0,1fr));gap:9px;margin:15px 0 13px 37px;display:grid}.mode-card{text-align:left;cursor:pointer;background:#fff;border:1px solid #dce2df;border-radius:5px;grid-template-columns:38px 1fr 18px;gap:9px;min-height:66px;padding:9px;display:grid}.mode-card.active{background:#f5fbf8;border-color:#4da184;box-shadow:inset 0 0 0 1px #4da184}.mode-icon{color:#146648;background:#e6f3ed;border-radius:5px;place-items:center;width:38px;height:38px;display:grid}.mode-card>span:nth-child(2){gap:4px;display:grid}.mode-card strong{font-size:11px}.mode-card small{color:var(--muted);font-size:9px}.mode-card>i{color:#fff;background:var(--green);border-radius:50%;place-items:center;width:17px;height:17px;display:grid}.mode-card:not(.active)>i{background:0 0;border:1px solid #c7d0cc}.ratio-editor{background:#f8faf9;border:1px solid #e8ecea;border-radius:5px;margin-left:37px;padding:11px 12px}.ratio-copy{color:#5f6b67;justify-content:space-between;font-size:9px;display:flex}.ratio-copy span{align-items:center;gap:5px;display:flex}.ratio-copy i{border-radius:2px;width:7px;height:7px}.ratio-track{background:#e6ebe8;border-radius:4px;gap:2px;height:8px;margin-top:9px;display:flex;overflow:hidden}.ratio-track i{height:100%;transition:width .2s;display:block}.form-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:15px 0 0 37px;display:grid}.form-grid label,.worker-form label{gap:6px;display:grid}.form-grid label>span,.worker-form label>span{color:#59655f;font-size:9px;font-weight:700}.form-grid select,.worker-form input,.worker-form select,.setting-row select{color:#34413d;background:#fff;border:1px solid #d9e0dd;border-radius:4px;outline:0;width:100%;height:38px;padding:0 10px;font-size:10px}.form-grid select:focus,.worker-form input:focus,.worker-form select:focus,.setting-row select:focus{border-color:#56a78b;box-shadow:0 0 0 3px #18835e14}.generate-button{color:#fff;background:var(--yellow);cursor:pointer;border:1px solid #0a8fab;border-radius:5px;justify-content:center;align-items:center;gap:8px;width:calc(100% - 37px);height:44px;margin:20px 0 0 37px;font-size:12px;font-weight:800;display:flex}.generate-button svg:last-child{margin-left:auto;margin-right:12px}.preview-panel{background:#202728;border:1px solid #303839;border-radius:7px;padding:15px;position:sticky;top:84px}.preview-toolbar{color:#fff;justify-content:space-between;align-items:center;padding:0 2px 13px;display:flex}.preview-toolbar>div{gap:3px;display:grid}.preview-toolbar span{color:#87938f;font-size:9px}.preview-toolbar strong{font-size:12px}.preview-toolbar button{color:#b6c0bc;background:#2a3334;border:1px solid #394243;border-radius:4px;place-items:center;width:29px;height:29px;display:grid}.badge-preview{background:#fff;border:1px solid #fff;border-radius:6px;width:min(100%,310px);margin:0 auto;overflow:hidden}.badge-top{color:#fff;background:#18201f;justify-content:space-between;align-items:center;min-height:39px;padding:0 13px;font-size:8px;display:flex}.mini-brand{color:var(--yellow);align-items:center;gap:5px;font-size:10px;font-weight:800;display:flex}.mini-brand img{object-fit:contain;background:#fff;width:16px;height:16px}.badge-worker{align-items:center;gap:10px;padding:13px 14px 7px;display:flex}.large-avatar{color:#32403b;background:#e8eeeb;border-radius:5px;place-items:center;width:45px;height:45px;font-size:12px;display:grid}.gate-worker .large-avatar{color:#fff;background:var(--cyan)}.badge-worker>div{flex:1;grid-template-columns:1fr auto;align-items:center;gap:2px 8px;display:grid}.badge-worker strong{font-size:17px}.badge-worker span{color:#5e6b66;font-size:9px}.badge-worker small{color:#75817c;grid-column:1/3;font-size:9px}.preview-qr{background:#fff;border:7px solid #f2f4f3;place-items:center;width:220px;height:220px;margin:3px auto 9px;display:grid;position:relative}.preview-qr img{width:196px;height:196px}.qr-state{color:#fff;white-space:nowrap;border-radius:3px;align-items:center;gap:4px;padding:4px 7px;font-size:8px;font-weight:700;display:flex;position:absolute;bottom:7px;left:50%;transform:translate(-50%)}.badge-meta{border-top:1px solid #e4e8e6;grid-template-columns:1.5fr 1fr;margin:0 13px;padding:9px 0;display:grid}.badge-meta span{color:#8a9490;gap:2px;font-size:7px;display:grid}.badge-meta strong{color:#36423e;font-size:9px}.badge-footer{color:#406253;background:#eaf5f0;justify-content:center;align-items:center;gap:5px;min-height:30px;font-size:7px;display:flex}.preview-actions{gap:8px;margin-top:12px}.preview-actions button{color:#d7dedb;cursor:pointer;background:#2b3435;border:1px solid #3a4445;border-radius:4px;flex:1;justify-content:center;align-items:center;gap:6px;height:37px;font-size:10px;display:flex}.security-note{color:#82908b;gap:6px;margin:11px 2px 0;font-size:8px}.batch-history{margin-top:14px;padding:18px}.batch-list{margin-top:13px}.batch-row{border-top:1px solid #edf0ee;grid-template-columns:36px minmax(180px,1fr) 80px 92px 86px 74px;gap:10px;min-height:58px;display:grid}.batch-icon{color:#17684e;background:#e8f4ef;border-radius:5px;place-items:center;width:33px;height:33px;display:grid}.batch-row>div,.batch-row>span:not(.batch-icon){gap:3px;display:grid}.batch-row strong{font-size:10px}.batch-row small{color:var(--muted);font-size:8px}.batch-status{color:#1a7052;grid-auto-flow:column;justify-content:start;align-items:center;font-size:9px;display:flex!important}.batch-row>button{color:#47534f;border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:4px;justify-content:center;align-items:center;gap:4px;height:29px;font-size:9px;display:flex}.gate-strip{grid-template-columns:repeat(4,minmax(0,1fr));gap:10px;margin-bottom:14px;display:grid}.gate-summary{min-height:68px;color:inherit;font:inherit;text-align:left;border:1px solid var(--line);cursor:pointer;background:#fff;border-radius:6px;grid-template-columns:38px 1fr 16px;align-items:center;gap:9px;padding:11px;transition:border-color .16s,box-shadow .16s,transform .16s;display:grid}.gate-summary:hover{border-color:#12a8c780;transform:translateY(-1px);box-shadow:0 14px 34px #0d283614}.gate-icon{color:#146b4d;background:#e4f2ec;border-radius:5px;place-items:center;width:38px;height:38px;display:grid}.gate-1{color:#236f9e;background:#e5f0f7}.gate-2{color:#4d6c82;background:#eff3f6}.gate-3{color:#0b607a;background:#e8f6fa}.gate-summary>span:nth-child(2){gap:4px;display:grid}.gate-strip strong{font-size:11px}.gate-strip small{color:var(--muted);font-size:8px}.gate-strip small i{background:#2cab7d;border-radius:50%;width:5px;height:5px;margin-right:4px;display:inline-block}.gate-strip svg:last-child{color:#9ba4a0}.gate-code-modal{width:min(100%,760px)}.gate-code-body{background:#f6fafb;grid-template-columns:minmax(280px,1fr) 280px;gap:18px;padding:18px;display:grid}.gate-screen-card{background:#fff;border:1px solid #dde5e2;border-radius:7px;padding:15px;box-shadow:0 18px 46px #08263814}.gate-screen-head,.gate-screen-title,.gate-live-stat{justify-content:space-between;align-items:center;display:flex}.gate-screen-head{border-bottom:1px solid #e6ece9;padding-bottom:12px}.gate-screen-head strong{color:var(--muted);font-size:9px}.gate-screen-title{justify-content:flex-start;gap:12px;padding:16px 0 10px}.gate-screen-title h3{color:var(--ink);margin:0;font-size:20px}.gate-screen-title p{color:var(--muted);margin:4px 0 0;font-size:11px}.gate-modal-qr{aspect-ratio:1;width:min(100%,270px);height:auto;margin:10px auto 0}.gate-modal-qr img{width:calc(100% - 24px);height:calc(100% - 24px)}.gate-modal-qr>svg{color:#8fa09a}.gate-code-side{align-content:start;gap:12px;display:grid}.gate-live-stat{gap:10px}.gate-live-stat span{color:var(--muted);background:#fff;border:1px solid #e0e7e4;border-radius:6px;flex:1;gap:4px;padding:13px;font-size:9px;display:grid}.gate-live-stat strong{color:var(--ink);font-size:20px}.gate-policy-list{background:#fff;border:1px solid #e0e7e4;border-radius:6px;gap:8px;padding:13px;display:grid}.gate-policy-list span{color:#31403b;align-items:center;gap:7px;font-size:11px;font-weight:750;display:flex}.gate-policy-list svg{color:var(--green)}.gate-code-tip{color:#4d5d57;background:#ecf7fa;border:1px solid #cfe8ef;border-radius:6px;margin:0;padding:13px;font-size:10px;line-height:1.8}.gate-code-footer{padding:14px 18px}.gate-code-footer>span{color:#4f625b;align-items:center;gap:6px;font-size:9px;display:flex}.attendance-layout{grid-template-columns:minmax(0,1fr) 330px;align-items:start;gap:14px;display:grid}.attendance-table .data-table{min-width:720px}.date-control{color:#50605a;border:1px solid var(--line);border-radius:4px;gap:6px;height:32px;padding:0 9px;font-size:9px}.method{align-items:center;gap:4px;display:inline-flex}.result-pill,.handled,.pending{border-radius:4px;gap:4px;width:fit-content;padding:4px 6px;font-size:8px}.result-pill.ok{color:#19684c;background:#e9f5ef}.result-pill.warn{color:#8f4444;background:#f8eaea}.result-pill.bad{color:#a54035;background:#fbe9e7}.handled{color:#49645a;background:#edf2ef}.pending{color:#8f4444;background:#f8eaea}.exception-panel{padding:17px}.exception-list{gap:9px;margin-top:14px;display:grid}.exception-item{background:#fafbfa;border:1px solid #e4e8e6;border-radius:5px;padding:12px}.exception-head{grid-template-columns:28px 1fr 32px;align-items:center;gap:8px;display:grid}.exception-head>div{gap:2px;display:grid}.exception-head strong{font-size:10px}.exception-head small,.exception-head time{color:var(--muted);font-size:8px}.exception-reason{color:#7c4c46;background:#fbeeed;border-radius:4px;justify-content:space-between;align-items:center;margin:10px 0;padding:8px;font-size:9px;display:flex}.exception-actions{gap:7px;display:flex}.exception-actions button{color:#9b443a;cursor:pointer;background:#fff;border:1px solid #e3c3bf;border-radius:4px;flex:1;justify-content:center;align-items:center;gap:5px;height:31px;font-size:9px;display:flex}.exception-actions button.pass{color:#fff;background:var(--green);border-color:var(--green)}.empty-state{color:#5f7b70;align-content:center;place-items:center;gap:7px;min-height:230px;display:grid}.empty-state strong{font-size:12px}.empty-state span{color:var(--muted);font-size:9px}.settings-layout{grid-template-columns:minmax(0,1fr) 300px;align-items:start;gap:14px;display:grid}.settings-main{overflow:hidden}.settings-section{border-bottom:1px solid var(--line);padding:21px}.settings-title{align-items:center;gap:10px;margin-bottom:11px;display:flex}.settings-title>span{color:#19684e;background:#e8f4ef;border-radius:5px;place-items:center;width:37px;height:37px;display:grid}.settings-title h2{margin:0;font-size:14px}.settings-title p{color:var(--muted);margin:3px 0 0;font-size:9px}.setting-row{border-top:1px solid #eef1ef;justify-content:space-between;align-items:center;gap:18px;min-height:55px;margin-left:47px;display:flex}.setting-row>div{gap:3px;display:grid}.setting-row strong{font-size:10px}.setting-row small{color:var(--muted);font-size:8px}.setting-row select{width:120px;height:32px}.toggle{cursor:pointer;background:#cbd2cf;border:0;border-radius:11px;width:38px;height:21px;padding:0;position:relative}.toggle span{background:#fff;border-radius:50%;width:15px;height:15px;transition:transform .16s;position:absolute;top:3px;left:3px}.toggle.active{background:var(--green)}.toggle.active span{transform:translate(17px)}.range-setting{background:#f7f9f8;border-radius:5px;margin:10px 0 0 47px;padding:12px}.range-setting>div{color:#64706c;justify-content:space-between;font-size:9px;display:flex}.range-setting>div strong{color:var(--green);font-size:11px}.range-setting input{width:100%;accent-color:var(--green)}.range-setting small{color:#9aa39f}.settings-footer{min-height:70px;color:var(--muted);background:#fafbfa;justify-content:space-between;align-items:center;padding:14px 21px;font-size:9px;display:flex}.rule-summary{text-align:center;padding:23px;position:sticky;top:84px}.summary-icon{color:#155f46;background:#e5f3ed;border-radius:7px;place-items:center;width:48px;height:48px;margin:0 auto 12px;display:grid}.rule-summary h2{margin:0;font-size:13px}.rule-summary>strong{color:#177253;margin:10px 0 5px;font-size:45px;line-height:1;display:block}.rule-summary>p{color:var(--muted);margin:0;font-size:9px;line-height:1.7}.rule-summary>div{text-align:left;border-top:1px solid var(--line);gap:8px;margin-top:18px;padding-top:15px;display:grid}.rule-summary>div span{color:#3f5f53;align-items:center;gap:6px;font-size:9px;display:flex}.rule-summary>div span.muted{color:#9ba4a0}.modal-backdrop{z-index:100;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);background:#0b12109e;place-items:center;padding:20px;display:grid;position:fixed;inset:0}.modal{background:#fff;border:1px solid #d8dfdc;border-radius:7px;width:min(100%,610px);overflow:hidden;box-shadow:0 24px 70px #08100d45}.modal-head{border-bottom:1px solid var(--line);justify-content:space-between;align-items:center;padding:17px 19px;display:flex}.modal-head>div{align-items:center;gap:10px;display:flex}.modal-icon{color:#155f46;background:#e5f3ed;border-radius:5px;place-items:center;width:38px;height:38px;display:grid}.modal-head h2{margin:0;font-size:15px}.modal-head p{color:var(--muted);margin:4px 0 0;font-size:9px}.import-progress{justify-content:center;align-items:center;gap:8px;padding:16px 20px 6px;display:flex}.import-progress span{color:#9aa39f;align-items:center;gap:5px;font-size:9px;display:flex}.import-progress span.active{color:#165e46;font-weight:700}.import-progress i{background:#edf0ee;border-radius:50%;place-items:center;width:20px;height:20px;font-style:normal;display:grid}.import-progress span.active i{color:#fff;background:var(--green)}.import-progress b{background:#dce1df;width:48px;height:1px}.modal-drop{cursor:pointer;background:#fafbfa;border:1px dashed #aebdb7;border-radius:6px;align-content:center;place-items:center;gap:7px;width:calc(100% - 40px);min-height:180px;margin:14px 20px;display:grid}.modal-drop input{display:none}.modal-drop>span{color:#17684d;background:#e5f3ed;border-radius:6px;place-items:center;width:45px;height:45px;display:grid}.modal-drop strong{font-size:12px}.modal-drop small{color:var(--muted);font-size:9px}.field-map{background:#f7f9f8;border-radius:5px;margin:0 20px 16px;padding:12px}.field-map>div{align-items:center;gap:7px;min-height:27px;display:flex}.field-map span{width:54px;color:var(--muted);font-size:8px}.field-map strong,.field-map em{border-radius:3px;align-items:center;gap:3px;padding:4px 6px;font-size:8px;font-style:normal;display:flex}.field-map em{color:#68746f;background:#ecefed}.modal-footer{border-top:1px solid var(--line);background:#fafbfa;justify-content:space-between;align-items:center;gap:14px;min-height:67px;padding:12px 19px;display:flex}.modal-footer>div{gap:8px;display:flex}.modal-footer button{cursor:pointer;background:#fff;border:1px solid #d6ddda;border-radius:4px;justify-content:center;align-items:center;gap:5px;height:35px;padding:0 12px;font-size:10px;display:flex}.modal-footer .primary-button{background:var(--yellow);border-color:#0a8fab}.modal-footer .primary-button:disabled{background:#e7eae8;border-color:#dce1df}.worker-form{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;padding:20px;display:grid}.privacy-tip{color:var(--muted);gap:5px;font-size:9px}.toast{z-index:130;color:#fff;background:#183c31;border:1px solid #2f5e4f;border-radius:5px;align-items:center;gap:8px;min-height:43px;padding:0 15px;font-size:11px;display:flex;position:fixed;bottom:24px;right:24px;box-shadow:0 14px 40px #0f221c33}.app-shell{background:linear-gradient(112deg,#ffffffb8,#e7f4f97a),0 0}.sidebar{width:244px;color:var(--ink);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#f8fbfcf0;border-right:1px solid #052b4c1c;padding:18px 17px 16px;box-shadow:18px 0 54px #052b4c0a}.brand-row{min-height:48px}.brand-mark{width:48px;height:48px;color:var(--ink);background:#ffffffc2;border:1px solid #052b4c29;border-radius:0;flex-basis:48px;padding:2px;position:relative}.brand-mark:after{content:"";display:none}.brand-mark img{object-fit:contain;width:44px;height:44px}.mobile-brand img{object-fit:contain;width:30px;height:30px}.mobile-brand span{gap:1px;display:grid}.brand-row strong{color:var(--ink);font-size:18px;font-weight:780}.brand-row small{color:#718292;font-size:9px;font-weight:760}.project-switch{color:var(--ink);background:#ffffffb8;border:1px solid #052b4c24;border-radius:0;margin:23px 0 30px;box-shadow:0 12px 30px #052b4c0b}.project-switch small,.admin-mini small{color:#718292}.project-icon{color:var(--cyan);background:#eaf5f8;border-radius:0}.nav-label{color:#087f99}.nav-item{color:#526878;border-radius:0}.nav-item:hover{color:var(--ink);background:#12a8c712}.nav-item.active{color:var(--ink);box-shadow:inset 3px 0 var(--cyan);background:#12a8c71a}.nav-item b{color:#fff;background:var(--danger)}.site-health{background:linear-gradient(#ffffffe6,#eaf3f7bd);border:1px solid #052b4c24;border-radius:0;box-shadow:0 18px 42px #052b4c12}.site-health-head span,.site-health-head strong,.device-grid b{color:var(--ink)}.site-health-head strong,.site-health button{color:#087f99}.device-grid span{color:#667b8b;background:#ffffffc7;border:1px solid #052b4c14;border-radius:0}.admin-mini{border-top-color:#052b4c21}.admin-avatar,.person-cell>span,.large-avatar{color:var(--ink);background:#eaf3f7;border-radius:0}.workspace{margin-left:244px}.topbar{-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#f8fbfce0;border-bottom-color:#052b4c17;height:76px;padding:0 max(30px,50vw - 770px)}.breadcrumb{color:#718292}.global-search{color:#7890a0;background:#ffffffb8;border-color:#052b4c1a;border-radius:0;height:40px}.global-search:focus-within{color:var(--cyan);border-color:var(--cyan);box-shadow:0 0 0 3px #12a8c71a}.icon-button,.primary-button,.secondary-button,.filter-button,.work-state,.attention-strip,.attention-icon,.kpi-card,.surface,.kpi-icon,.delta-up,.event-mark,.event-result,.quick-actions button,.quick-actions button>span,.selection-bar button,.checkbox>span,.status-pill,.safety-pill,.row-more,.table-footer button,.step-heading>span,.selected-people,.person-token,.person-token>span:first-child,.mode-card,.mode-icon,.ratio-editor,.form-grid select,.generate-button,.preview-panel,.preview-toolbar button,.badge-preview,.large-avatar,.qr-state,.batch-icon,.batch-row>button,.gate-summary,.gate-icon,.date-control,.result-pill,.handled,.pending,.exception-item,.exception-reason,.exception-actions button,.settings-title>span,.range-setting,.summary-icon,.modal,.modal-icon,.modal-drop,.field-map,.field-map strong,.field-map em,.modal-footer button,.worker-form input,.worker-form select,.toast{border-radius:0}.icon-button{color:var(--ink);background:#ffffffc7}.primary-button{color:#fff;background:var(--ink);border-color:var(--ink);box-shadow:0 12px 28px #052b4c1f}.primary-button:hover{background:var(--navy);border-color:var(--cyan)}.secondary-button,.filter-button{color:var(--ink);background:#ffffffb8;border-color:#052b4c33}.page-wrap{padding-top:34px}.page-heading{min-height:68px;margin-bottom:24px}.page-heading h1{color:var(--ink);font-family:var(--display-serif);font-size:38px;font-weight:600}.page-heading p{color:#5f7585;font-size:13px}.work-state{color:#087f99;background:#12a8c714;border:1px solid #12a8c738}.attention-strip{border-color:#12a8c747;border-left-color:var(--cyan);background:#eef8fbeb;box-shadow:0 18px 42px #052b4c0b}.attention-icon{color:var(--ink);background:#12a8c71a;border:1px solid #12a8c72e}.attention-strip span,.attention-strip button{color:#4a6879}.kpi-card,.surface{-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#ffffffe6;border-color:#052b4c21;box-shadow:0 18px 46px #052b4c11}.kpi-card:before{content:"";background:var(--kpi-color);width:42px;height:2px;position:absolute;top:0;left:0}.kpi-card:after{width:0}.kpi-card.yellow{--kpi-color:#12a8c7;--kpi-soft:#edf8fa;--kpi-ink:#087f99}.kpi-card.green{--kpi-color:#0b56a2;--kpi-soft:#edf4fa;--kpi-ink:#0b56a2}.kpi-card.blue{--kpi-color:#657f94;--kpi-soft:#eff3f6;--kpi-ink:#4d6c82}.kpi-card.red{--kpi-color:#c45151;--kpi-soft:#fbefef;--kpi-ink:#a64343}.kpi-icon{border:1px solid #052b4c14}.surface-head h2,.step-heading h2,.settings-title h2,.rule-summary h2{color:var(--ink);font-family:var(--display-serif);font-weight:600}.surface-head h2{font-size:18px}.surface-head button,.delta-up,.site-health button{color:#087f99}.bar i{background:#0b56a285}.bar.peak i{background:var(--cyan)}.legend-dot.dynamic{background:var(--blue,#0b56a2)}.legend-dot.static{background:var(--cyan)}.event-mark.ok,.quick-actions button>span,.batch-icon,.settings-title>span,.summary-icon,.modal-icon,.modal-drop>span{color:#087f99;background:#eaf5f8}.event-result.ok,.status-在场,.safety-已培训,.result-pill.ok{color:#0b6284;background:#ebf6f9}.quick-actions button{background:#f7fbfce0;border-color:#052b4c1a}.quick-actions button:hover{border-color:var(--cyan);box-shadow:0 12px 28px #12a8c714}.table-toolbar,.data-table th,.modal-footer{background:#f6f9fbd1}.filter-tabs button.active,.scan-time{color:var(--ink)!important}.filter-tabs button.active:after{background:var(--cyan)}.selection-bar{color:var(--ink);background:#12a8c714;border-color:#12a8c733}.selection-bar .selection-primary,.checkbox input:checked+span,.toggle.active,.exception-actions button.pass{background:var(--ink);border-color:var(--ink)}.data-table tbody tr:hover,.data-table tbody tr.row-active{background:#12a8c70b}.person-cell>span{border-color:#052b4c1a}.table-footer button.active{background:var(--ink);border-color:var(--ink)}.step-heading>span{background:var(--ink)}.selected-people,.ratio-editor,.range-setting{background:#eff7fab8;border-color:#052b4c1a}.person-token.active,.mode-card.active{border-color:var(--cyan);box-shadow:inset 0 0 0 1px var(--cyan);background:#ecf8fbd1}.mode-icon{color:#087f99;background:#eaf5f8}.mode-card>i{background:var(--cyan)}.ratio-static{background:#6d8192}.ratio-dynamic{background:var(--cyan)}.generate-button{color:#fff;background:var(--ink);border-color:var(--ink);box-shadow:0 16px 38px #052b4c29}.generate-button:hover{border-color:var(--cyan);background:var(--navy)}.preview-panel{color:var(--ink);background:linear-gradient(#fffffff5,#eaf5f9e6);border-color:#052b4c24;box-shadow:0 34px 90px #052b4c24}.preview-toolbar{color:var(--ink)}.preview-toolbar span,.security-note{color:#6d8192}.preview-toolbar button,.preview-actions button{color:var(--ink);background:#ffffffb3;border-color:#052b4c29}.preview-actions button.dark{color:#fff;background:var(--ink);border-color:var(--ink)}.badge-top{background:var(--ink)}.mini-brand,.qr-state.dynamic{color:#fff}.mini-brand{color:var(--cyan-strong,#0fd1e8)}.qr-state.dynamic{background:var(--navy)}.qr-state.static{color:var(--ink);background:var(--cyan)}.badge-footer{color:#0b607a;background:#eaf5f8}.gate-summary{background:#ffffffe6;border-color:#052b4c21;box-shadow:0 14px 34px #052b4c0d}.gate-icon,.gate-1,.gate-2,.gate-3{color:#087f99;background:#eaf5f8}.settings-footer{background:#f6f9fbd6}.rule-summary>strong{color:#087f99;font-family:var(--display-serif)}.modal-backdrop{background:#051b2d94}.modal{box-shadow:0 34px 90px #052b4c38}.import-progress span.active,.privacy-tip{color:#087f99}.import-progress span.active i{background:var(--ink)}.modal-drop.dragging{border-color:var(--cyan);background:#edf8fa}.field-map strong{color:#087f99;background:#eaf5f8}.modal-footer .primary-button{color:#fff;background:var(--ink);border-color:var(--ink)}.toast{background:var(--ink);border-color:var(--cyan);box-shadow:0 18px 44px #052b4c33}@media (width<=1220px){.sidebar{width:210px}.workspace{margin-left:210px}.dashboard-grid{grid-template-columns:minmax(0,1.3fr) minmax(300px,.9fr)}.qr-workspace{grid-template-columns:minmax(0,1fr) 330px}.global-search{width:190px}}@media (width<=1050px){.mobile-brand{grid-template-columns:30px 1fr;align-items:center;gap:8px;display:grid}.mobile-brand strong{color:var(--ink);font-size:14px}.mobile-brand small{color:#718292;font-size:7px;font-weight:760}.sidebar{align-items:center;width:76px;padding-inline:10px}.brand-row>div:not(.brand-mark),.project-switch>span:nth-child(2),.project-switch>svg,.nav-label,.nav-item span,.site-health,.admin-mini>span:nth-child(2),.admin-mini>svg{display:none}.project-switch{grid-template-columns:1fr;width:44px;padding:5px;display:grid}.nav-list{width:100%}.nav-item{grid-template-columns:1fr;place-items:center;width:100%;padding:0;display:grid}.nav-item b{margin:-22px -30px 0 0;position:absolute}.admin-mini{grid-template-columns:32px}.workspace{margin-left:76px}.dashboard-grid{grid-template-columns:1fr}.qr-workspace{grid-template-columns:minmax(0,1fr) 320px}.attendance-layout{grid-template-columns:1fr}.exception-panel{position:static}.gate-strip{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=820px){.sidebar{align-items:stretch;width:236px;padding:22px 16px 16px;transition:transform .18s;transform:translate(-105%);box-shadow:20px 0 45px #09100e3d}.sidebar.mobile-open{transform:translate(0)}.sidebar.mobile-open .brand-row>div:not(.brand-mark),.sidebar.mobile-open .project-switch>span:nth-child(2),.sidebar.mobile-open .project-switch>svg,.sidebar.mobile-open .nav-label,.sidebar.mobile-open .nav-item span,.sidebar.mobile-open .site-health,.sidebar.mobile-open .admin-mini>span:nth-child(2),.sidebar.mobile-open .admin-mini>svg{display:grid}.sidebar.mobile-open .project-switch{grid-template-columns:32px 1fr 16px;width:100%;padding:11px 10px;display:grid}.sidebar.mobile-open .nav-item{place-items:initial;grid-template-columns:20px 1fr auto;width:100%;padding:0 11px;display:grid}.sidebar.mobile-open .admin-mini{grid-template-columns:32px 1fr 17px}.mobile-close{color:#c4cdca;background:0 0;border-color:#394142;margin-left:auto;display:grid}.workspace{margin-left:0}.menu-button{display:grid}.mobile-brand{grid-template-columns:30px 1fr;align-items:center;gap:8px;margin-right:auto;display:grid}.mobile-brand strong{color:var(--ink);font-size:14px}.mobile-brand small{color:#718292;font-size:7px;font-weight:760}.breadcrumb{display:none}.topbar{padding:0 18px}.page-wrap{padding:22px 18px 36px}.global-search{width:min(45vw,220px)}.qr-workspace,.settings-layout{grid-template-columns:1fr}.preview-panel,.rule-summary{position:static}.batch-row{grid-template-columns:36px minmax(160px,1fr) 70px 80px}.batch-row>span:nth-of-type(4),.batch-row>button{display:none}}@media (width<=620px){.topbar{gap:8px;height:58px;padding:0 12px}.top-actions{margin-left:auto}.global-search{color:#35413d;border-color:var(--line);background:#fff;width:36px;padding:0 9px}.global-search input{opacity:0;width:0}.global-search:focus-within{width:calc(100% - 150px);position:absolute;right:96px}.global-search:focus-within input{opacity:1;width:100%}.compact-action{width:36px;padding:0;font-size:0}.page-wrap{padding:18px 12px 30px}.page-heading{align-items:flex-end;margin-bottom:16px}.page-heading h1{font-size:20px}.page-heading p{max-width:300px;line-height:1.5}.page-actions{flex-wrap:wrap;justify-content:flex-end}.page-actions .secondary-button:first-child{display:none}.attention-strip{align-items:flex-start}.attention-strip button{white-space:nowrap;padding-right:0}.kpi-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px}.kpi-card{min-height:125px;padding:13px}.kpi-card>div:nth-child(2){gap:4px;display:grid}.kpi-card>div:nth-child(2) strong{font-size:25px}.attendance-chart,.live-panel,.workforce-panel,.quick-panel{padding:14px}.bar-chart{gap:4px}.live-row{grid-template-columns:28px minmax(80px,1fr) 35px}.live-row .event-result,.chart-legend span:last-child{display:none}.table-toolbar{flex-direction:column;align-items:flex-start;gap:8px;min-height:auto;padding:0 12px 10px}.filter-tabs{gap:13px;width:100%;height:51px;overflow-x:auto}.filter-tabs button{flex:none}.selection-bar{flex-direction:column;align-items:flex-start}.selection-bar>div{width:100%;overflow-x:auto}.selection-bar button{white-space:nowrap}.gate-strip{grid-template-columns:1fr}.issuer-panel{padding:15px}.dual-code-brief{grid-template-columns:1fr}.brief-metrics{grid-template-columns:repeat(3,minmax(0,1fr))}.selected-people,.gate-code-list,.mode-cards,.ratio-editor,.form-grid,.generate-button{margin-left:0}.mode-cards,.gate-code-list,.form-grid{grid-template-columns:1fr}.generate-button{width:100%}.batch-history{padding:14px}.batch-row{grid-template-columns:34px 1fr 65px}.batch-row>span:nth-of-type(3),.batch-row>span:nth-of-type(4),.batch-row>button{display:none}.settings-section{padding:16px}.setting-row,.range-setting{margin-left:0}.worker-form{grid-template-columns:1fr;max-height:62vh;overflow-y:auto}.gate-code-body{grid-template-columns:1fr;padding:14px}.gate-code-side{gap:10px}.gate-live-stat{flex-direction:column}.gate-code-footer{flex-direction:column;align-items:stretch;gap:10px}.gate-code-footer>div{width:100%}.gate-code-footer>div button{flex:1}.modal-footer{flex-direction:column;align-items:stretch}.modal-footer>div{width:100%}.modal-footer>div button{flex:1}.field-map>div{flex-wrap:wrap}.field-map span{width:100%}.import-progress b{width:22px}.notice-popover{width:calc(100vw - 24px);position:fixed;top:64px;right:12px}.toast{justify-content:center;bottom:12px;left:12px;right:12px}}@media (prefers-reduced-motion:reduce){*,:before,:after{scroll-behavior:auto!important;transition-duration:.01ms!important}}
