:root{--bg:#f8faf8;--bg-panel:#fff;--bg-soft:#f8faf7;--bg-hover:#eef4f0;--border:#e2eae5;--border-strong:#d2ddd7;--ink:#18211d;--ink-2:#34433c;--ink-3:#67786f;--ink-4:#9aa9a2;--ink-5:#c7d0cb;--accent:#18c486;--accent-soft:#18c4861c;--accent-2:#0ea66e;--good:oklch(64% .16 156);--warn:oklch(70% .13 75);--bad:oklch(58% .13 28);--info:oklch(65% .1 235);--radius:6px;--radius-lg:10px;--shadow-sm:0 1px 0 #1c45340a;--shadow-md:0 8px 28px -12px #1c453429, 0 1px 2px #1c45340d;--shadow-lg:0 30px 70px -26px #1c453447, 0 6px 16px #1c453414}*{box-sizing:border-box;scrollbar-width:thin;scrollbar-color:color-mix(in oklab, var(--ink-4) 58%, transparent) transparent}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background-color:color-mix(in oklab, var(--ink-4) 45%, transparent);background-clip:content-box;border:2px solid #0000;border-radius:999px}::-webkit-scrollbar-thumb:hover{background-color:color-mix(in oklab, var(--ink-3) 55%, transparent)}html,body,#root{margin:0;padding:0}body{color:var(--ink);background:var(--bg);-webkit-font-smoothing:antialiased;font-feature-settings:"tnum" 0, "kern" 1;font-family:-apple-system,PingFang SC,Source Han Sans CN,Noto Sans SC,Microsoft YaHei,Helvetica Neue,Helvetica,Arial,sans-serif;font-size:13px;line-height:1.55}.num,.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum" 1}.mono{font-family:JetBrains Mono,SF Mono,Menlo,Consolas,monospace}button{font:inherit;color:inherit;cursor:pointer}input,select,textarea{font:inherit;color:inherit}a{color:inherit;text-decoration:none}a:hover{color:var(--accent)}.shell{grid-template-columns:224px 1fr;min-height:100vh;display:grid}@media (width<=1024px){.shell{grid-template-columns:64px 1fr}.sidebar-brand{justify-content:center;padding:18px 0 16px}.sidebar-brand>div:last-child{display:none}.nav-section{padding:14px 6px 4px}.nav-label{display:none}.nav-item{justify-content:center;padding:9px 8px}.nav-item>span:not(.nav-icon){display:none}.nav-badge{margin-left:0;padding:0 4px;font-size:9px;position:absolute;top:2px;right:4px}.sidebar-foot{justify-content:center;padding:12px 0}.sidebar-foot>div:not(.avatar-mini),.sidebar-foot>svg{display:none}.topbar{padding:0 16px}.top-actions .search{width:36px;min-width:0;padding:6px}.top-actions .search input,.top-actions .search .tag{display:none}.page{padding:16px}}.crumb{white-space:nowrap;text-overflow:ellipsis;min-width:0;overflow:hidden}@media (width<=1100px){.crumb .muted{display:none}}.sidebar{border-right:1px solid var(--border);background:linear-gradient(#f8fbfa 0%,#f4f8f6 100%);flex-direction:column;height:100vh;display:flex;position:sticky;top:0}.sidebar-brand{border-bottom:1px solid var(--border);align-items:center;gap:10px;padding:18px 18px 16px;display:flex}.brand-mark{background:linear-gradient(135deg, var(--accent) 0%, #60d7b1 100%);color:#fff;letter-spacing:-.02em;border-radius:6px;flex-shrink:0;place-items:center;width:28px;height:28px;font-size:13px;font-weight:600;display:grid}.brand-mark.lg{border-radius:12px;width:52px;height:52px;font-size:24px}.brand-text{letter-spacing:-.005em;font-size:13.5px;font-weight:600}.brand-sub{color:var(--ink-3);letter-spacing:.01em;margin-top:1px;font-size:11px}.nav-section{padding:14px 10px 4px}.nav-label{text-transform:uppercase;letter-spacing:.08em;color:var(--ink-4);padding:0 10px 6px;font-size:10.5px}.nav-item{color:var(--ink-2);cursor:pointer;-webkit-user-select:none;user-select:none;border-radius:5px;align-items:center;gap:10px;padding:7px 10px;font-size:13px;display:flex;position:relative}.nav-item:hover{color:var(--ink);background:#ffffff8c}.nav-item.active{color:var(--ink);box-shadow:var(--shadow-sm);background:#fff;font-weight:500}.nav-item.active .nav-icon{color:var(--accent)}.nav-icon{width:16px;height:16px;color:var(--ink-3);flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.nav-badge{background:var(--accent);color:#fff;border-radius:8px;margin-left:auto;padding:1px 6px;font-size:10px;font-weight:500}.sidebar-foot{border-top:1px solid var(--border);align-items:center;gap:10px;margin-top:auto;padding:12px 14px;display:flex}.avatar-mini{width:28px;height:28px;color:var(--accent-2);background:#e5f6ef;border-radius:50%;flex-shrink:0;place-items:center;font-size:12px;font-weight:500;display:grid}.topbar{background:var(--bg-panel);border-bottom:1px solid var(--border);z-index:5;align-items:center;height:56px;padding:0 24px;display:flex;position:sticky;top:0}.crumb{color:var(--ink-3);align-items:center;gap:8px;font-size:12.5px;display:flex}.crumb .sep{color:var(--ink-5)}.crumb .current{color:var(--ink);font-weight:500}.top-actions{align-items:center;gap:8px;margin-left:auto;display:flex}.main{flex-direction:column;min-width:0;display:flex}.page{min-width:0;padding:24px 32px 48px}@media (width<=1280px){.page{padding:20px 24px 40px}}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:22px;display:flex}.page-title{letter-spacing:-.012em;font-size:20px;font-weight:600}.page-sub{color:var(--ink-3);margin-top:4px;font-size:12.5px}.btn{border:1px solid var(--border-strong);background:var(--bg-panel);color:var(--ink);white-space:nowrap;border-radius:5px;align-items:center;gap:6px;padding:6px 12px;font-size:12.5px;font-weight:500;transition:all .12s;display:inline-flex}.btn:hover{border-color:var(--ink-3)}.btn:disabled{opacity:.55;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg, var(--accent) 0%, #10b978 100%);color:#fff;border-color:#0000;box-shadow:0 10px 20px -12px #18c486b8}.btn-primary:hover{background:linear-gradient(135deg, #23d492 0%, var(--accent-2) 100%);color:#fff;border-color:#0000}.btn-accent{background:var(--accent);color:#fff;border-color:var(--accent)}.btn-accent:hover{background:var(--accent-2);border-color:var(--accent-2);color:#fff}.btn-ghost{color:var(--ink-2);background:0 0;border-color:#0000}.btn-ghost:hover{background:var(--bg-hover);color:var(--ink)}.btn-danger:hover{color:var(--bad);border-color:var(--bad)}.btn-sm{padding:4px 9px;font-size:12px}.btn-lg{padding:8px 16px;font-size:13px}.input,.select{background:var(--bg-panel);border:1px solid var(--border-strong);color:var(--ink);border-radius:5px;align-items:center;min-width:0;padding:6px 10px;font-size:12.5px;display:inline-flex}.input:focus,.select:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.input[type=date],.input[type=time],.input[type=datetime-local],.input[type=month]{min-height:31px;line-height:1.4;display:inline-block}.form-row input.input,.form-row select.select,.form-row textarea.input,.modal-body input.input,.modal-body select.select,.modal-body textarea.input{width:100%}textarea.input{resize:vertical;min-height:60px;padding:8px 10px}.tab{white-space:nowrap}.search{background:var(--bg-panel);border:1px solid var(--border-strong);color:var(--ink-3);border-radius:5px;align-items:center;gap:6px;min-width:220px;padding:6px 10px;font-size:12.5px;display:inline-flex}.search input{background:0 0;border:none;outline:none;flex:1}.search svg{color:var(--ink-4);flex-shrink:0}.search-select{min-width:0;display:inline-flex;position:relative}.search-select.grow{flex:1}.form-row .search-select,.modal-body .search-select{width:100%}.search-select-trigger{background:var(--bg-panel);border:1px solid var(--border-strong);width:100%;min-height:32px;color:var(--ink);text-align:left;border-radius:5px;justify-content:space-between;align-items:center;gap:8px;padding:6px 10px;font-size:12.5px;display:inline-flex}.search-select-trigger:hover{border-color:var(--ink-3)}.search-select-trigger:focus{outline:2px solid var(--accent-soft);border-color:var(--accent)}.search-select-trigger:disabled{opacity:.55;cursor:not-allowed}.search-select-trigger svg{color:var(--ink-4);flex-shrink:0}.search-select-value{text-overflow:ellipsis;white-space:nowrap;flex:1;min-width:0;overflow:hidden}.search-select-value.placeholder{color:var(--ink-4)}.search-select-menu{z-index:80;background:var(--bg-panel);border:1px solid var(--border-strong);box-shadow:var(--shadow-lg);border-radius:6px;flex-direction:column;padding:6px;display:flex;position:fixed}.search-select-search{border:1px solid var(--border);color:var(--ink-3);background:var(--bg-soft);border-radius:5px;flex-shrink:0;align-items:center;gap:6px;margin-bottom:4px;padding:6px 8px;display:flex}.search-select-search input{background:0 0;border:0;outline:0;flex:1;min-width:0}.search-select-search svg{color:var(--ink-4);flex-shrink:0}.search-select-options{min-height:0;overflow:auto}.search-select-option{width:100%;color:var(--ink);text-align:left;background:0 0;border:0;border-radius:4px;justify-content:space-between;align-items:center;gap:8px;padding:7px 8px;font-size:12.5px;display:flex}.search-select-option:hover,.search-select-option.active{background:var(--bg-hover)}.search-select-option:disabled{opacity:.45;cursor:not-allowed}.search-select-option-label{text-overflow:ellipsis;white-space:nowrap;min-width:0;overflow:hidden}.search-select-option-meta{color:var(--ink-3);flex-shrink:0;font-size:11.5px}.search-select-empty{color:var(--ink-3);text-align:center;padding:16px 8px;font-size:12px}.card{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden}.card-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;gap:12px;padding:14px 18px;display:flex}.card-title{font-size:13.5px;font-weight:600}.card-sub{color:var(--ink-3);font-size:12px}.card-body{padding:18px}.card-body.flush{padding:0}.kpi{background:var(--bg-panel);border:1px solid var(--border);border-radius:var(--radius-lg);padding:16px 18px;position:relative}.kpi-label{color:var(--ink-3);align-items:center;gap:6px;font-size:12px;display:flex}.kpi-value{letter-spacing:-.02em;font-variant-numeric:tabular-nums;margin-top:6px;font-size:28px;font-weight:600}.kpi-value .unit{color:var(--ink-3);margin-left:2px;font-size:14px;font-weight:400}.kpi-meta{color:var(--ink-3);gap:10px;margin-top:4px;font-size:11.5px;display:flex}.kpi-meta .delta-up{color:var(--good)}.kpi-meta .delta-down{color:var(--bad)}.tbl{border-collapse:collapse;width:100%;font-size:12.5px}.tbl th,.tbl td{text-align:left;border-bottom:1px solid var(--border);padding:10px 14px}.tbl th{color:var(--ink-3);letter-spacing:.02em;background:var(--bg-soft);font-size:11.5px;font-weight:500}.tbl tr:last-child td{border-bottom:none}.tbl tbody tr:hover{background:var(--bg-soft)}.tbl td.num{font-variant-numeric:tabular-nums}.tbl th.seq-col,.tbl td.seq-col{text-align:center;width:56px;color:var(--ink-3);white-space:nowrap}.sort-th{width:100%;color:inherit;font:inherit;letter-spacing:inherit;text-align:left;background:0 0;border:0;align-items:center;gap:4px;padding:0;display:inline-flex}.sort-th:hover,.sort-th.active{color:var(--ink)}.sort-indicator{width:10px;height:10px;color:var(--ink-4);opacity:.75;flex-shrink:0;justify-content:center;align-items:center;display:inline-flex}.sort-th:hover .sort-indicator,.sort-th.active .sort-indicator{color:var(--ink);opacity:1}.tbl .row-actions{opacity:0;justify-content:flex-end;gap:4px;transition:opacity .12s;display:flex}.tbl tr:hover .row-actions{opacity:1}.tbl .row-actions button{padding:3px 7px;font-size:12px}.tag{background:var(--bg-hover);color:var(--ink-2);border:1px solid #0000;border-radius:4px;align-items:center;gap:4px;padding:1px 8px;font-size:11.5px;display:inline-flex}.tag.subtle{border-color:var(--border);color:var(--ink-3);background:0 0}.tag.outline{border-color:var(--border-strong);color:var(--ink-2);background:0 0}.dot{background:var(--ink-4);border-radius:50%;flex-shrink:0;width:6px;height:6px;display:inline-block}.dot.good{background:var(--good)}.dot.warn{background:var(--warn)}.dot.bad{background:var(--bad)}.dot.info{background:var(--info)}.status{align-items:center;gap:5px;font-size:11.5px;display:inline-flex}.status-on_time{color:var(--good)}.status-late{color:var(--warn)}.status-absent{color:var(--bad)}.status-leave{color:var(--info)}.status-makeup{color:var(--ink-3)}.status-pending{color:var(--ink-4)}.avatar{width:28px;height:28px;color:var(--ink);background:#d9d0bb;border-radius:50%;flex-shrink:0;place-items:center;font-size:11px;font-weight:500;display:inline-grid}.avatar-lg{width:56px;height:56px;font-size:18px}.avatar-xl{border-radius:14px;width:88px;height:88px;font-size:28px}.avatar.no-photo{color:var(--ink-4);background:repeating-linear-gradient(135deg,#eef5f1 0 6px,#e4eee9 6px 12px)}.tabs{border-bottom:1px solid var(--border);scrollbar-width:none;gap:4px;padding:0 18px;display:flex;overflow:auto hidden}.tabs::-webkit-scrollbar{display:none}.tab{color:var(--ink-3);cursor:pointer;-webkit-user-select:none;user-select:none;border-bottom:2px solid #0000;margin-bottom:-1px;padding:11px 14px;font-size:13px}.tab:hover{color:var(--ink-2)}.tab.active{color:var(--ink);border-bottom-color:var(--ink);font-weight:500}.filters{background:var(--bg-soft);border-bottom:1px solid var(--border);flex-wrap:wrap;align-items:center;gap:8px;padding:12px 18px;display:flex}.filters .label{color:var(--ink-3);font-size:12px}.attendance-records-panel{border:1px solid var(--border);border-radius:8px;overflow:hidden}.row{align-items:center;gap:12px;display:flex}.col{flex-direction:column;gap:12px;display:flex}.grow{flex:1;min-width:0}.muted{color:var(--ink-3)}.tiny{font-size:11.5px}.sep-v{background:var(--border);align-self:stretch;width:1px}.spacer{flex:1}.grid-2{grid-template-columns:1fr 1fr;gap:16px;display:grid}.grid-3{grid-template-columns:1fr 1fr 1fr;gap:16px;display:grid}.grid-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}@media (width<=1280px){.grid-4{grid-template-columns:repeat(2,1fr)}}.kpis{grid-template-columns:repeat(4,1fr);gap:14px;margin-bottom:18px;display:grid}@media (width<=1100px){.kpis{grid-template-columns:repeat(2,1fr)}}.dash-grid{grid-template-columns:1.5fr 1fr;align-items:start;gap:16px;display:grid}@media (width<=1280px){.dash-grid{grid-template-columns:1fr}}.dashboard-overview-grid{--dashboard-panel-height:380px;align-items:stretch}.dashboard-overview-grid>.card{height:var(--dashboard-panel-height);flex-direction:column;min-height:0;display:flex}.dashboard-overview-grid .card-body{flex:1;min-height:0}.dashboard-chart-card .chart-area{align-items:center;display:flex}.dashboard-chart-card .chart-area svg{height:100%;max-height:270px}.dashboard-abnormal-list{scrollbar-gutter:stable;overflow-y:auto}.modal-back{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:50;background:#1a1a1a59;place-items:center;padding:24px;display:grid;position:fixed;inset:0}.modal{background:var(--bg-panel);box-shadow:var(--shadow-lg);border-radius:12px;flex-direction:column;width:100%;max-width:640px;max-height:86vh;display:flex;overflow:hidden}.modal-head{border-bottom:1px solid var(--border);justify-content:space-between;align-items:center;padding:18px 22px;display:flex}.modal-title{letter-spacing:-.01em;font-size:16px;font-weight:600}.modal-body{padding:22px;overflow:auto}.modal-foot{border-top:1px solid var(--border);background:var(--bg-soft);justify-content:flex-end;gap:8px;padding:14px 22px;display:flex}.form-row{flex-direction:column;gap:6px;margin-bottom:14px;display:flex}.form-row label{color:var(--ink-2);font-size:12.5px;font-weight:500}.form-row .hint{color:var(--ink-3);font-size:11.5px}.form-row .req{color:var(--bad);margin-left:2px}.form-2col{grid-template-columns:1fr 1fr;gap:14px;display:grid}.steps{align-items:center;gap:0;margin-bottom:22px;display:flex}.step{color:var(--ink-4);align-items:center;gap:8px;font-size:12.5px;display:flex}.step-num{background:var(--bg-hover);width:22px;height:22px;color:var(--ink-4);border-radius:50%;place-items:center;font-size:11.5px;font-weight:500;display:grid}.step.active .step-num{background:var(--ink);color:#fff}.step.done .step-num{background:var(--accent);color:#fff}.step.active{color:var(--ink)}.step.done{color:var(--ink-2)}.step-line{background:var(--border);width:36px;height:1px;margin:0 12px}.step.done+.step-line{background:var(--accent)}.login-bg{background:var(--bg);background-image:radial-gradient(at 20% 30%,#18c48612,#0000 45%),radial-gradient(at 80% 70%,#f4c6451a,#0000 45%);place-items:center;min-height:100vh;display:grid}.login-card{background:var(--bg-panel);width:360px;box-shadow:var(--shadow-md);border:1px solid var(--border);border-radius:14px;padding:32px}.platform-login{min-height:100vh;color:var(--ink);background:radial-gradient(circle at 4% 16%,#1ac5860f,#0000 28%),linear-gradient(90deg,#fafcfb 0%,#fbfdfb 52%,#fff 52% 100%);grid-template-columns:minmax(620px,1.1fr) minmax(460px,.9fr);display:grid;overflow-x:hidden}.platform-login .stage{background-color:#fbfdfb;background-image:url(/login-stage-bg-desktop.webp);background-position:50%;background-repeat:no-repeat;background-size:cover;flex-direction:column;min-width:0;padding:clamp(34px,4.8vw,60px);display:flex;position:relative;overflow:hidden}.platform-login .stage-brand{align-items:center;gap:10px;display:flex}.platform-login .stage-mark{background:linear-gradient(135deg, var(--accent) 0%, #51dbac 100%);color:#fff;border-radius:12px;place-items:center;width:42px;height:42px;font-size:19px;font-weight:700;display:grid;box-shadow:0 14px 28px -18px #11a66cd9}.platform-login .stage-name{letter-spacing:-.01em;font-size:18px;font-weight:700}.platform-login .stage-sub{color:var(--ink-3);margin-top:1px;font-size:13px}.platform-login .stage-hero{z-index:1;flex:1;align-items:flex-start;min-height:0;padding-top:clamp(62px,10vh,120px);display:flex;position:relative}.platform-login .stage-copy{width:100%;min-width:0;max-width:520px}.platform-login .stage-hero h1{letter-spacing:-.02em;color:#202923;margin:0 0 22px;font-size:clamp(38px,4.5vw,58px);font-weight:800;line-height:1.17}.platform-login .stage-hero h1:after{content:"";background:var(--accent);border-radius:50%;width:12px;height:12px;margin-left:8px;display:inline-block;box-shadow:0 0 0 6px #18c48621}.platform-login .stage-hero p{color:var(--ink-2);overflow-wrap:anywhere;max-width:470px;margin:0;font-size:16px;line-height:1.85}.platform-login .stage-foot{z-index:1;color:var(--ink-3);margin-top:clamp(20px,3vh,34px);font-size:12px;position:relative}.platform-login .form-stage{color:var(--ink);background:radial-gradient(circle at 70% 14%,#18c48609,#0000 26%),linear-gradient(#fff 0%,#fafffc 100%);place-items:center;padding:clamp(34px,5vw,72px);display:grid}.platform-login .form-card{-webkit-backdrop-filter:blur(18px);backdrop-filter:blur(18px);background:#ffffffe0;border:1px solid #dae8e1d1;border-radius:24px;width:100%;max-width:500px;padding:clamp(34px,4vw,56px);box-shadow:0 32px 92px -42px #1e413242}.platform-login .login-card-icon{width:58px;height:58px;color:var(--accent-2);background:linear-gradient(135deg,#e5faf2 0%,#d7f4ea 100%);border-radius:18px;place-items:center;margin:0 auto 24px;display:grid}.platform-login .form-card h2{letter-spacing:-.012em;text-align:center;margin:0 0 8px;font-size:28px;font-weight:800}.platform-login .form-card .sub{color:var(--ink-3);text-align:center;margin-bottom:34px;font-size:14px}.platform-login .login-field{align-items:center;display:flex;position:relative}.platform-login .login-field svg{color:var(--ink-4);pointer-events:none;position:absolute;left:18px}.platform-login .login-field .input{background:#fff;border-color:#d6e2dd;border-radius:10px;height:58px;padding:0 18px 0 50px;font-size:14px;box-shadow:0 1px #1c453405}.platform-login .login-field .input::placeholder{color:var(--ink-4)}.platform-login .login-field .input:focus{border-color:var(--accent);outline:4px solid #18c4861f}.platform-login .form-card .btn-primary{border-radius:10px;height:58px;margin-top:8px;font-size:15px;font-weight:700}.platform-login .login-safe-note{color:var(--ink-3);background:linear-gradient(135deg,#f0fbf6 0%,#f8fffc 100%);border:1px solid #e0f2ea;border-radius:12px;gap:12px;margin-top:28px;padding:16px 18px;font-size:13px;line-height:1.65;display:flex}.platform-login .login-safe-note span{color:#fff;background:var(--accent);border-radius:10px;flex-shrink:0;place-items:center;width:28px;height:28px;display:grid}@media (width<=1180px){.platform-login{background:#fbfdfb;height:100dvh;min-height:0;display:block;position:relative;overflow:hidden}.platform-login .stage{background-image:url(/login-stage-bg-tablet.webp);background-position:bottom;height:100%;min-height:0;padding:clamp(30px,4vw,48px);position:absolute;inset:0}.platform-login .stage-hero{padding-top:clamp(54px,8vh,82px)}.platform-login .stage-copy{max-width:min(440px,45vw)}.platform-login .stage-hero h1{margin-bottom:16px;font-size:clamp(34px,4vw,46px)}.platform-login .stage-hero p{max-width:min(420px,45vw);font-size:14px;line-height:1.75}.platform-login .stage-foot{margin:0;position:absolute;bottom:clamp(24px,4vh,40px);left:clamp(30px,4vw,48px)}.platform-login .form-stage{pointer-events:none;background:0 0;justify-content:flex-end;align-items:center;padding:clamp(24px,5vw,56px);display:flex;position:absolute;inset:0}.platform-login .form-card{pointer-events:auto;background:#fffffff0;max-width:420px;padding:clamp(26px,3vw,36px);box-shadow:0 34px 92px -36px #1e413257}.platform-login .login-card-icon{width:52px;height:52px;margin-bottom:18px}.platform-login .form-card h2{font-size:25px}.platform-login .form-card .sub{margin-bottom:24px}.platform-login .login-field .input,.platform-login .form-card .btn-primary{height:52px}.platform-login .login-safe-note{margin-top:20px;padding:13px 15px}}@media (width>=761px) and (width<=900px){.platform-login .stage-copy{max-width:340px}.platform-login .stage-hero h1{font-size:34px}.platform-login .stage-hero p{max-width:330px}.platform-login .form-stage{padding-right:28px}.platform-login .form-card{max-width:380px}}@media (width<=760px){.platform-login .stage{background-image:url(/login-stage-bg-mobile.webp);background-position:bottom;padding:24px 22px}.platform-login .stage-mark{border-radius:11px;width:40px;height:40px;font-size:18px}.platform-login .stage-name{font-size:16px}.platform-login .stage-sub{font-size:12px}.platform-login .stage-hero{flex:initial;padding-top:30px}.platform-login .stage-hero h1{margin-bottom:11px;font-size:29px;line-height:1.12}.platform-login .stage-hero h1:after{width:10px;height:10px;margin-left:7px}.platform-login .stage-copy{max-width:calc(100vw - 44px)}.platform-login .stage-hero p{word-break:break-word;max-width:calc(100vw - 44px);font-size:13px;line-height:1.55}.platform-login .stage-foot{left:22px;right:22px;bottom:max(16px, env(safe-area-inset-bottom));text-align:center;font-size:11px}.platform-login .form-stage{justify-content:center;align-items:center;padding:224px 18px 58px}.platform-login .form-card{border-radius:20px;max-width:390px;padding:18px 20px}.platform-login .login-card-icon{display:none}.platform-login .form-card h2{margin-bottom:4px;font-size:24px}.platform-login .form-card .sub{margin-bottom:14px;font-size:13px}.platform-login .form-row{gap:5px;margin-bottom:10px}.platform-login .form-row label{font-size:12px}.platform-login .login-field svg{left:15px}.platform-login .login-field .input{height:46px;padding-left:44px}.platform-login .form-card .btn-primary{height:48px;margin-top:4px}.platform-login .login-safe-note{gap:9px;margin-top:10px;padding:10px 12px;font-size:11.5px;line-height:1.45}.platform-login .login-safe-note span{border-radius:8px;width:24px;height:24px}}@media (width<=760px) and (height<=620px){.platform-login .stage{padding-top:20px}.platform-login .stage-mark{width:36px;height:36px;font-size:16px}.platform-login .stage-hero{padding-top:24px}.platform-login .stage-hero h1{margin-bottom:10px;font-size:27px}.platform-login .stage-hero p{font-size:12.5px;line-height:1.55}.platform-login .stage-foot{bottom:max(10px, env(safe-area-inset-bottom));font-size:10.5px}.platform-login .form-stage{padding-top:184px;padding-bottom:38px}.platform-login .form-card{border-radius:18px;padding:16px 18px}.platform-login .form-card .sub{margin-bottom:12px}.platform-login .login-safe-note{display:none}}.terminal-screen{color:#f1efe9;aspect-ratio:16/10;box-shadow:var(--shadow-lg);background:#0e0f0e;border-radius:14px;position:relative;overflow:hidden}.terminal-cam{background:radial-gradient(at 50% 40%,#dcd2be14,#0000 50%),linear-gradient(#18191a 0%,#0e0f0e 100%);position:absolute;inset:0}.terminal-grid{background-image:linear-gradient(90deg,#ffffff05 1px,#0000 1px),linear-gradient(#ffffff05 1px,#0000 1px);background-size:32px 32px;position:absolute;inset:0}.cal{background:var(--border);border:1px solid var(--border);border-radius:8px;grid-template-columns:repeat(7,1fr);gap:1px;display:grid;overflow:hidden}.cal-cell{background:var(--bg-panel);min-height:64px;padding:6px 8px;font-size:11.5px;position:relative}.cal-cell.off{background:var(--bg-soft);color:var(--ink-4)}.cal-cell .d{font-variant-numeric:tabular-nums;font-size:12px;font-weight:500}.cal-cell.holiday{background:oklch(96% .04 28)}.cal-cell.holiday .d{color:var(--bad)}.cal-cell.makeup{background:oklch(96% .04 240)}.cal-cell.makeup .d{color:var(--info)}.cal-cell.closed{background:var(--bg-hover)}.cal-cell .ev{color:var(--ink-2);margin-top:4px;font-size:10.5px;line-height:1.3}.chart-area{padding:10px 6px 0;position:relative}.divider{background:var(--border);height:1px;margin:14px 0}.scroll-y{overflow-y:auto}.tnum{font-variant-numeric:tabular-nums}.detail-grid{grid-template-columns:320px 1fr;gap:16px;display:grid}@media (width<=1100px){.detail-grid{grid-template-columns:1fr}}.kv{grid-template-columns:88px 1fr;gap:4px 12px;font-size:12.5px;display:grid}.kv dt{color:var(--ink-3)}.kv dd{color:var(--ink);margin:0}.bar-row{grid-template-columns:1fr 80px 44px;align-items:center;gap:10px;padding:7px 0;display:grid}.bar-row .name{font-size:12.5px}.bar-track{background:var(--bg-hover);border-radius:99px;height:5px;position:relative;overflow:hidden}.bar-fill{background:var(--accent);border-radius:99px;position:absolute;top:0;bottom:0;left:0}.bar-row .val{text-align:right;font-variant-numeric:tabular-nums;color:var(--ink-2);font-size:12px}.empty{text-align:center;color:var(--ink-3);padding:64px 24px}.loading-state{color:var(--ink-3);padding:28px 24px}.loading-label{margin-bottom:14px;font-size:12px}.skeleton-stack{flex-direction:column;gap:9px;display:flex}.skeleton-line{background:linear-gradient(90deg, var(--bg-hover), color-mix(in oklab, var(--bg-hover) 45%, white), var(--bg-hover));background-size:180% 100%;border-radius:999px;height:12px;animation:1.15s ease-in-out infinite skeleton-shimmer}.query-error{border:1px solid color-mix(in oklab, var(--bad) 28%, var(--border));background:color-mix(in oklab, var(--bad) 7%, var(--bg-panel));color:var(--ink-2);border-radius:8px;align-items:center;gap:12px;margin:18px;padding:16px;display:flex}.query-error svg{color:var(--bad);flex-shrink:0}.query-error .btn{margin-left:auto}@keyframes skeleton-shimmer{0%{background-position:120% 0}to{background-position:-80% 0}}.tbl-foot{border-top:1px solid var(--border);background:var(--bg-soft);justify-content:space-between;align-items:center;padding:12px 18px;display:flex}.switch{border:1px solid var(--border-strong);appearance:none;cursor:pointer;vertical-align:middle;background:#d8d3c7;border-radius:999px;align-items:center;width:40px;height:24px;padding:2px;transition:background .14s,border-color .14s,box-shadow .14s;display:inline-flex}.switch:hover{border-color:var(--ink-4)}.switch:focus-visible{outline:2px solid var(--accent-soft);outline-offset:2px}.switch.on{background:var(--accent);border-color:var(--accent)}.switch-thumb{background:#fff;border-radius:50%;width:18px;height:18px;transition:transform .14s;display:block;transform:translate(0);box-shadow:0 1px 3px #1a1a1a38,inset 0 1px #fffc}.switch.on .switch-thumb{transform:translate(16px)}.toast-wrap{z-index:100;flex-direction:column;align-items:center;gap:8px;display:flex;position:fixed;bottom:24px;left:50%;transform:translate(-50%)}.toast{box-shadow:var(--shadow-lg);background:var(--ink);color:#fafaf8;border-radius:8px;padding:10px 18px;font-size:12.5px}.toast.error{background:var(--bad);color:#fff}.toast.success{background:var(--accent);color:#fff}
