:root{--font-sans:system-ui,-apple-system,"Segoe UI","Hiragino Kaku Gothic ProN","Hiragino Sans","Noto Sans JP","Yu Gothic UI","Meiryo",sans-serif;--font-num:ui-monospace,"SF Mono","Segoe UI",system-ui,sans-serif;--navy:#053765;--navy2:#0a4577;--teal:#007A9D;--teal2:#0a93ba;--teal50:#e6f3f7;--teal100:#cfeaf1;--ink:#0f2233;--muted:#6b7a8d;--line:#e7ebf1;--bg:#f4f6f9;--card:#fff;--ok:#0f9d6b;--ok50:#e6f6ef;--warn:#d92d20;--warn50:#fdeceb;--amber:#b45309;--amber50:#fdf3e7;--violet:#6d4bd6;--slate:#5b6b7d;--row-h:34px;--row-h-compact:28px;--fs-body:13px;--fs-sub:11.5px;--fs-kpi:22px;--sp-1:4px;--sp-2:8px;--sp-3:12px;--sp-4:16px;--cell-x:12px;--cell-y:8px;--tap:32px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-sans);background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased}.num{font-family:var(--font-num);font-variant-numeric:tabular-nums}svg.i{width:18px;height:18px;stroke:currentColor;stroke-width:1.8;fill:none;stroke-linecap:round;stroke-linejoin:round;display:block}.app{display:flex;height:100dvh;min-height:0;overflow:hidden}.rail{width:60px;background:var(--navy);display:flex;flex-direction:column;align-items:center;padding-top:12px;gap:4px;flex:0 0 60px}.rail .mk{width:38px;height:38px;border-radius:11px;background:#04223f;display:flex;align-items:center;justify-content:center;margin-bottom:8px}.rail a{width:40px;height:40px;border-radius:10px;display:flex;align-items:center;justify-content:center;color:#92a8bf;text-decoration:none}.rail a.on{background:#ffffff21;color:#fff}.rail a.on svg{stroke:#5cc2db}.rail .foot{margin-top:auto;margin-bottom:10px;width:34px;height:34px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--navy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.rail .railsep{width:26px;height:1px;background:#ffffff24;margin:5px 0}.rail--wide{width:60px;flex:0 0 60px;align-items:stretch;padding-top:10px;gap:2px;overflow-y:auto;overflow-x:hidden}.rail--wide .sidenav-hd{display:flex;align-items:center;gap:9px;padding:2px 0 8px;justify-content:center}.rail--wide .sidenav-brand{display:none;color:#fff;font-weight:800;font-size:15px;letter-spacing:.2px}.rail--wide .sidenav-groups{display:flex;flex-direction:column;gap:2px;width:100%}.rail--wide .sidenav-group-hd{display:none;align-items:center;gap:6px;width:100%;border:0;background:transparent;color:#8fa6bd;font-size:var(--fs-sub);font-weight:800;font-family:inherit;text-align:left;padding:7px 12px 4px;cursor:pointer}.rail--wide .sidenav-group-hd:hover{color:#cfe0ee}.rail--wide .sidenav-group-hd:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}.rail--wide .sidenav-caret{width:13px;height:13px;flex:0 0 13px;transition:transform .15s ease}.rail--wide .sidenav-group.is-collapsed .sidenav-caret{transform:rotate(-90deg)}.rail--wide .sidenav-group-label{flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.rail--wide .sidenav-rollup{display:none}.rail--wide .sidenav-group-body{display:flex;flex-direction:column;gap:1px;overflow:hidden}.rail--wide .navitem{display:flex;align-items:center;gap:10px;width:auto;min-height:var(--tap);height:38px;padding:0;margin:0 8px;justify-content:center;border-radius:10px;color:#92a8bf;text-decoration:none;cursor:pointer;position:relative}.rail--wide .navitem:hover{background:#ffffff12;color:#cfe0ee}.rail--wide .navitem.on{background:#ffffff21;color:#fff}.rail--wide .navitem.on .navitem-ic{stroke:#5cc2db}.rail--wide .navitem:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}.rail--wide .navitem-ic{width:20px;height:20px;flex:0 0 20px}.rail--wide .navitem-label{display:none;flex:1 1 auto;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;font-size:var(--fs-body);font-weight:600}.rail--wide .navitem-badge{display:none}.nav-badge:empty{display:none}.rail--wide .foot{margin-top:auto;margin-bottom:10px;width:34px;height:34px;align-self:center;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--navy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}@media (min-width:1025px){.rail--wide{width:208px;flex:0 0 208px;padding:12px 0 0;gap:4px}.rail--wide .sidenav-hd{justify-content:flex-start;padding:0 14px 10px}.rail--wide .sidenav-brand{display:inline}.rail--wide .sidenav-group-hd{display:flex}.rail--wide .sidenav-group.is-collapsed .sidenav-group-body{max-height:0}.rail--wide .sidenav-group-body{max-height:600px;transition:max-height .18s ease}.rail--wide .sidenav-rollup:not(:empty){display:inline-block;margin-left:auto;min-width:18px;text-align:center;font-family:var(--font-num);font-weight:800;font-size:10.5px;color:#cfe0ee;background:#ffffff24;border-radius:8px;padding:0 5px}.rail--wide .navitem{justify-content:flex-start;padding:0 12px;margin:0 8px}.rail--wide .navitem-label{display:block}.rail--wide .navitem-badge:not(:empty){display:inline-block;margin-left:auto;min-width:18px;text-align:center;font-family:var(--font-num);font-weight:800;font-size:10.5px;color:#fff;background:var(--warn);border-radius:8px;padding:0 5px}}.b-navy{background:#e7eef6;color:var(--navy)}.main{flex:1;display:flex;flex-direction:column;min-width:0;min-height:0}.top{height:56px;background:#fff;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:12px;padding:0 18px}.top .tt{font-size:17px;font-weight:700;display:flex;align-items:center;gap:9px}.top .tt .lg{color:var(--teal)}.top .sp{flex:1}.company{display:flex;align-items:center;gap:8px;padding:7px 11px;border:1px solid var(--line);border-radius:9px;font-weight:600;font-size:13px}.company .dot{width:8px;height:8px;border-radius:50%;background:var(--ok)}.search{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:8px 11px;color:var(--muted);font-size:13px;min-width:260px}.global-search{flex:0 1 360px;min-width:0}.gs-input{display:flex;align-items:center;gap:8px;background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:7px 11px;color:var(--muted)}.gs-input:focus-within{border-color:var(--teal);background:#fff}.gs-input svg{flex:0 0 auto;color:var(--muted)}.gs-input input{border:0;background:transparent;outline:none;font-family:inherit;font-size:13px;color:var(--ink);width:100%;min-width:0}.gs-input input::placeholder{color:var(--muted)}.gs-panel{position:absolute;top:calc(100% + 6px);left:0;right:0;background:#fff;border:1px solid var(--line);border-radius:12px;box-shadow:0 12px 32px #05376529;max-height:min(70vh,440px);overflow-y:auto;z-index:50;padding:6px}.gs-empty{padding:14px 12px;text-align:center;margin:0}.gs-group{padding:4px 0}.gs-group+.gs-group{border-top:1px solid var(--line)}.gs-group-hd{display:flex;align-items:center;gap:6px;padding:6px 10px 4px;font-size:11.5px;font-weight:700;color:var(--muted);text-transform:none}.gs-group-hd svg{color:var(--teal)}.search-result{display:flex;align-items:center;gap:9px;width:100%;border:0;background:transparent;padding:8px 10px;border-radius:8px;font-family:inherit;font-size:13px;color:var(--ink);text-align:left;cursor:pointer}.search-result:hover,.search-result:focus-visible{background:var(--teal50)}.search-result svg{flex:0 0 auto;color:var(--navy)}.search-result .gs-label{font-weight:600;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.search-result .gs-sub{margin-left:auto;flex:0 0 auto;font-size:12px}.iconbtn{width:36px;height:36px;border-radius:9px;border:1px solid var(--line);background:#fff;display:flex;align-items:center;justify-content:center;position:relative;color:var(--muted)}.iconbtn .badge{position:absolute;top:-5px;right:-5px;background:var(--warn);color:#fff;font-size:10px;font-weight:700;border-radius:10px;padding:1px 5px;font-family:var(--font-num)}.avatar{width:36px;height:36px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--navy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:13px}.seg{display:flex;background:#eef1f5;border-radius:9px;padding:3px}.seg button{border:0;background:transparent;padding:6px 14px;font-size:13px;font-weight:700;color:var(--muted);font-family:inherit;border-radius:7px;cursor:pointer}.seg button.on{background:#fff;color:var(--navy);box-shadow:0 1px 2px #0537651f}.btn{display:inline-flex;align-items:center;gap:7px;border:1px solid var(--line);background:#fff;color:var(--ink);border-radius:9px;padding:8px 13px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer}.btn.pri{background:var(--navy);color:#fff;border-color:var(--navy)}.btn.teal{background:linear-gradient(135deg,var(--teal),#0892b6);color:#fff;border:0;box-shadow:0 2px 8px #007a9d47}.btn.sm{padding:6px 10px;font-size:12px}.btn:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.btn:hover{filter:brightness(.97)}.btn:disabled{opacity:.55;cursor:default}.seg button:focus-visible,.tabs a:focus-visible,.tabs button:focus-visible,.inp:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.tag{font-size:9px;background:#ffffff40;border-radius:5px;padding:1px 5px;font-weight:700}.content{padding:20px 22px;overflow:auto;flex:1;min-height:0}.ph{display:flex;align-items:center;gap:12px;margin-bottom:4px}.ph h1{font-size:20px;font-weight:800}.ph .sp{flex:1}.sub{color:var(--muted);font-size:13px;margin:2px 0 16px}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin-bottom:14px}.tabs a,.tabs button{padding:9px 14px;font-size:13px;font-weight:700;color:var(--muted);border-bottom:2px solid transparent;text-decoration:none}.tabs button{border-top:0;border-left:0;border-right:0;background:none;font-family:inherit;cursor:pointer}.tabs a.on,.tabs button.on{color:var(--navy);border-bottom-color:var(--teal)}.filters{display:flex;align-items:center;gap:8px;margin-bottom:14px;flex-wrap:wrap}.fchip{display:flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:#334;background:#fff;border:1px solid var(--line);border-radius:9px;padding:7px 11px}.fchip.on{background:var(--navy);color:#fff;border-color:var(--navy)}.fchip.warn{color:var(--warn);background:var(--warn50);border-color:#f7c9c5;font-weight:700}.card{background:var(--card);border:1px solid var(--line);border-radius:14px}.card .hd{display:flex;align-items:center;gap:10px;padding:13px 16px;border-bottom:1px solid var(--line)}.card .hd h3{font-size:14.5px;font-weight:700}.card .hd .more{margin-left:auto;color:var(--teal);font-size:12.5px;font-weight:600}.card .bd{padding:14px 16px}.kpis{display:grid;gap:14px;margin-bottom:18px}.kpi{background:#fff;border:1px solid var(--line);border-radius:14px;padding:16px;position:relative;overflow:hidden;min-width:0}.kpi .l{font-size:12px;color:var(--muted);font-weight:700;display:flex;align-items:center;gap:7px}.kpi .v{font-size:26px;font-weight:800;margin-top:8px;min-width:0;overflow-wrap:anywhere;line-height:1.15}.kpi .v small{font-size:13px;color:var(--muted);font-weight:600}.kpi .chip{display:inline-block;font-size:11px;font-weight:700;border-radius:6px;padding:2px 7px;margin-top:7px}.kpi.hero{background:linear-gradient(135deg,#063a69,#0a5a73);color:#fff;border:0}.kpi.hero .l{color:#bfe0ea}.kpi.hero .v{font-size:clamp(22px,4.4vw,36px);color:#fff}.kpi.hero .v.num,.kpi.hero .v .num{color:#fff}.kpi.hero .v small{color:#bfe0ea}.kpi.risk{border-color:#f7c9c5;background:var(--warn50)}.kpi.act{cursor:pointer;text-align:left;width:100%;font:inherit;color:inherit;display:block}.kpi.act:hover{box-shadow:0 4px 14px #05376524}.kpi.act:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.home-kpis,.kpis.cols4{grid-template-columns:repeat(4,1fr)}.home-lists{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.card .hd button.more{margin-left:auto;background:none;border:0;font-family:inherit;cursor:pointer;padding:0}.card .hd button.more:hover{text-decoration:underline}.card .hd button.more:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:4px}.card .hd .more.plain{color:var(--muted);font-weight:600}.chip.up{background:var(--ok50);color:var(--ok)}.chip.dn{background:var(--warn50);color:var(--warn)}.chip.tl{background:var(--teal50);color:var(--teal)}.chip.am{background:var(--amber50);color:var(--amber)}#home-view{display:flex;flex-direction:column;min-height:100%;gap:0}#home-view .home-lists{flex:1 1 auto;min-height:0}#home-view .home-lists>.card{display:flex;flex-direction:column;min-height:0;overflow:hidden}#home-view .home-lists>.card .hd{flex:0 0 auto}#home-view .home-lists>.card>.tbl{display:block;overflow:auto;min-height:0}#home-shortage>.tbl{flex:1 1 auto;min-height:0}.shortage-hero{flex:0 0 auto;display:flex;align-items:baseline;gap:6px;flex-wrap:wrap;padding:12px 14px;margin:0 0 2px;border-radius:12px;background:var(--bg);border:1px solid var(--line)}.shortage-hero.risk{background:var(--warn50);border-color:#f7c9c5}.shortage-hero.ok{background:var(--ok50);border-color:#bfe6cf}.shortage-hero-lead{font-size:12px;font-weight:700;color:var(--muted)}.shortage-hero-num{font-family:var(--font-num);font-variant-numeric:tabular-nums;font-weight:800;font-size:clamp(26px,4.2vw,38px);line-height:1;color:var(--warn)}.shortage-hero-num.sm{font-size:clamp(20px,3vw,26px)}.shortage-hero.ok .shortage-hero-num{color:var(--ok)}.shortage-hero-unit{font-size:13px;font-weight:700;color:var(--muted)}.shortage-hero-sep{font-size:18px;color:var(--line);margin:0 2px}.shortage-hero-ok{display:inline-flex;align-items:center;font-size:13px;font-weight:700;color:var(--ok)}.home-shortage-row .shortage-rank{width:24px;text-align:center;font-family:var(--font-num);font-weight:800;color:var(--muted)}.home-shortage-row .shortage-site{min-width:0}.home-shortage-row .shortage-site-name{font-weight:700;display:block;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-shortage-row .shortage-shifts{display:block;font-size:11.5px;color:var(--muted);margin-top:1px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.home-shortage-row .shortage-count{white-space:nowrap}.home-shortage-row .shortage-act{width:1%;text-align:right;white-space:nowrap}.shortage-rollup{background:none;border:0;font:inherit;cursor:pointer;color:var(--teal);font-weight:700;padding:4px 0;min-height:var(--tap);display:inline-flex;align-items:center}.shortage-rollup:hover{text-decoration:underline}.shortage-rollup:focus-visible{outline:2px solid var(--teal);outline-offset:2px;border-radius:4px}#home-view #home-projects-card{flex:0 0 auto;display:flex;flex-direction:column;min-height:0;max-height:42vh;overflow:hidden}#home-view #home-projects-card>.tbl{display:block;overflow:auto;min-height:0}@media (max-width:768px){.home-shortage-row .shortage-shifts{white-space:normal}}.list-view{display:flex;flex-direction:column;min-height:100%;gap:0}.list-view>.seg{flex:0 0 auto;margin-bottom:14px}.list-view>.scr-actions{flex:0 0 auto}.list-view>.card{flex:1 1 auto;display:flex;flex-direction:column;min-height:0;overflow:hidden}.list-view>.card>.hd{flex:0 0 auto}.list-view>.card>.tbl-wrap{flex:1 1 auto;min-height:0;overflow:auto}.tbl tbody tr.customer:hover,.tbl tbody tr.staff-row:hover,.tbl tbody tr.vendor-row:hover,.tbl.no-rowlink tbody tr:hover{background:transparent}.tbl{width:100%;border-collapse:collapse;font-size:13px}.tbl thead th{text-align:left;font-size:11.5px;font-weight:700;color:var(--muted);padding:10px 12px;border-bottom:1px solid var(--line);white-space:nowrap;background:#fbfcfe;position:sticky;top:0;z-index:1}.tbl tbody td{padding:11px 12px;border-bottom:1px solid var(--line);vertical-align:middle}.tbl tbody tr:hover{background:#fafcfe}.tbl-wrap{overflow-x:auto}.tbl .num{font-family:var(--font-num);font-variant-numeric:tabular-nums}.tbl .r,.tbl td.r,.tbl th.r{text-align:right}.tbl td.leave-remaining{border-left:1px solid var(--line);font-weight:600}.tbl td.grp-sep,.tbl th.grp-sep{border-left:1px solid var(--line)}.leave-taken-violation{color:var(--warn);font-weight:700}.twocol{align-items:start}.badge{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;border-radius:20px;padding:3px 9px}.b-ok{background:var(--ok50);color:var(--ok)}.b-warn{background:var(--warn50);color:var(--warn)}.b-am{background:var(--amber50);color:var(--amber)}.b-tl{background:var(--teal50);color:var(--teal)}.b-mut{background:var(--bg);color:var(--slate)}.b-vi{background:#efe9fb;color:var(--violet)}.dotb{width:7px;height:7px;border-radius:50%;background:currentColor;display:inline-block}.av{width:30px;height:30px;border-radius:50%;background:linear-gradient(135deg,var(--teal),var(--navy));color:#fff;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:12px;font-family:var(--font-num)}.avg{display:flex}.avg i{width:24px;height:24px;border-radius:50%;background:var(--teal);color:#fff;font-size:9.5px;font-style:normal;display:flex;align-items:center;justify-content:center;border:2px solid #fff;margin-left:-7px;font-weight:700;font-family:var(--font-num)}.avg i:first-child{margin-left:0}.avg i.lead{background:var(--amber)}.mypage-grid{display:grid;grid-template-columns:220px 1fr;gap:16px;align-items:start}.mypage-fields{display:grid;grid-template-columns:1fr 1fr;gap:12px}.field{margin-bottom:14px}.field label,.field>span{display:block;font-size:12.5px;font-weight:700;margin-bottom:6px}.field label .req{color:var(--warn);margin-left:3px}.inp{width:100%;border:1px solid var(--line);border-radius:9px;padding:10px 12px;font-size:13px;font-family:inherit;background:#fff;color:var(--ink)}.inp::placeholder{color:#aab6c4}.inp.ro{background:var(--bg);color:var(--muted)}.hintrow{font-size:11.5px;color:var(--muted);margin-top:5px}.mp-subnav>.bd{padding:var(--sp-2)}.mp-tab{display:flex;align-items:center;gap:10px;width:100%;min-height:var(--tap);padding:0 11px;margin:2px 0;border:none;border-radius:9px;background:transparent;color:var(--muted);font-weight:600;font-size:var(--fs-body);font-family:inherit;text-align:left;cursor:not-allowed;opacity:.6}.mp-tab .i{width:17px;height:17px;flex:0 0 auto}.mp-tab.on{background:var(--teal50);color:var(--navy);font-weight:700;opacity:1;cursor:default}.mp-tab:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.mp-cards{display:flex;flex-direction:column;gap:16px}.mp-card>.bd,.mp-profile-head>.bd{padding:14px 16px}.mp-card-hd{display:flex;align-items:center;gap:7px;margin-bottom:12px;padding-bottom:9px;border-bottom:1px solid var(--line)}.mp-card-hd .i{width:16px;height:16px;color:var(--teal)}.mp-card-hd h4{margin:0;font-size:13px;font-weight:800;color:var(--navy)}.mp-head-row{display:flex;align-items:center;gap:14px;flex-wrap:wrap}.mp-avatar{width:52px;height:52px;font-size:21px;flex:0 0 auto}.mp-head-id{min-width:0;flex:1 1 auto}.mp-head-id h3{margin:0 0 5px;font-size:16px;line-height:1.2}.mp-head-meta{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.mp-head-meta .badge .i{width:13px;height:13px}.mp-company{display:inline-flex;align-items:center;gap:5px;font-size:var(--fs-sub);color:var(--muted);font-weight:600;min-width:0}.mp-company .i{width:14px;height:14px;flex:0 0 auto}.mp-company{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:100%}.mp-head-actions{display:flex;align-items:center;gap:8px;margin-left:auto;flex-wrap:wrap}.mp-head-actions .btn.sm{min-height:var(--tap)}.mp-head-actions .btn[disabled]{opacity:.5}.mp-field{margin-bottom:0}.mp-card-row{display:grid;grid-template-columns:1fr 1fr;gap:16px;align-items:start}.mp-statlist{margin:0;display:flex;flex-direction:column;gap:2px}.mp-stat{display:flex;align-items:center;justify-content:space-between;gap:12px;min-height:var(--tap);padding:6px 0;border-bottom:1px solid var(--line)}.mp-stat:last-child{border-bottom:none}.mp-stat dt{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-body);font-weight:600;color:var(--ink);min-width:0}.mp-stat dt .i{width:15px;height:15px;flex:0 0 auto;color:var(--muted)}.mp-stat dd{margin:0;font-size:var(--fs-body);color:var(--ink);text-align:right;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.mp-stat dd.mp-stat-act{overflow:visible}.mp-stat dd .badge .i{width:13px;height:13px}.mp-stat-act .btn.sm{min-height:var(--tap)}.mp-stat-act .btn[disabled]{opacity:.5}.mp-note{margin:2px 0 0}.grid2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.grid3{display:grid;grid-template-columns:1fr 1fr 1fr;gap:14px}.doc-form-grid{display:grid;grid-template-columns:1fr 320px;gap:16px;align-items:start}.doc-form-grid>*{min-width:0}.pager{display:flex;align-items:center;gap:6px;justify-content:flex-end;margin-top:12px;font-size:12.5px;color:var(--muted)}.pager b{font-family:var(--font-num)}.pager .pg{width:30px;height:30px;border:1px solid var(--line);border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;font-weight:700}.pager .pg.on{background:var(--navy);color:#fff;border-color:var(--navy)}.lg-wrap{display:flex;min-height:100vh}.lg-brand{flex:1.05;background:linear-gradient(150deg,#053765,#06477f 55%,#0a6f8c);color:#fff;padding:54px 56px;display:flex;flex-direction:column;position:relative;overflow:hidden}.lg-brand .arc{position:absolute;right:-120px;top:-120px;width:420px;height:420px;border:34px solid rgba(255,255,255,.05);border-radius:50%}.lg-brand .arc2{position:absolute;right:30px;bottom:-160px;width:360px;height:360px;border:28px solid rgba(92,194,219,.1);border-radius:50%}.lg-logo{display:flex;align-items:center;gap:12px}.lg-logo .wm{font-size:30px;font-weight:800;letter-spacing:.5px}.lg-logo .wm b{color:#fff}.lg-logo .wm i{color:#5cc2db;font-style:normal}.lg-h{font-size:34px;font-weight:800;line-height:1.4;margin-top:auto}.lg-h em{color:#5cc2db;font-style:normal}.lg-sub{font-size:15px;color:#bfe0ea;margin-top:16px;line-height:1.9;font-weight:500}.lg-feat{display:flex;gap:10px;margin-top:26px;flex-wrap:wrap}.lg-feat span{font-size:12.5px;font-weight:700;background:#ffffff1a;border:1px solid rgba(255,255,255,.14);border-radius:20px;padding:7px 13px;display:flex;align-items:center;gap:7px}.lg-feat span svg{color:#5cc2db;width:15px;height:15px}.lg-foot{margin-top:34px;font-size:12px;color:#9fc2d0}.lg-form{flex:.95;display:flex;align-items:center;justify-content:center;padding:40px;background:var(--bg)}.lg-card{width:380px}.lg-card h2{font-size:23px;font-weight:800}.lg-card .p{color:var(--muted);font-size:13px;margin:6px 0 26px}.ipw{position:relative}.ipw svg{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#aab6c4;width:17px;height:17px}.ipw .inp{padding-left:38px}.lg-row{display:flex;align-items:center;justify-content:space-between;margin:6px 0 20px;font-size:12.5px}.lg-row a{color:var(--teal);font-weight:700;text-decoration:none}.lg-btn{width:100%;justify-content:center;padding:12px;font-size:14px}.lg-mfa{margin-top:18px;font-size:11.5px;color:var(--muted);display:flex;align-items:center;gap:7px;background:var(--teal50);border:1px solid var(--teal100);border-radius:9px;padding:9px 12px}.lg-mfa svg{color:var(--teal);width:15px;height:15px;flex:0 0 15px}.lg-err{color:var(--warn);background:var(--warn50);border:1px solid #f7c9c5;border-radius:9px;padding:9px 12px;font-size:12.5px;font-weight:600;margin-bottom:14px}.lg-companies{display:flex;flex-direction:column;gap:10px}.lg-companies .company{width:100%;cursor:pointer;justify-content:flex-start;font-size:14px;padding:13px 14px}.lg-companies .company:focus-visible{outline:2px solid var(--teal);outline-offset:2px}@media (max-width:768px){.lg-wrap{flex-direction:column}.lg-brand{display:none}.lg-form{padding:24px}.lg-card{width:100%;max-width:380px}.lg-card .inp,.lg-card .lg-btn,.lg-companies .company{min-height:44px}}.scr-actions{display:flex;gap:8px;align-items:center;margin:10px 0}.detailcard{margin-top:18px}.detailcard:focus{outline:none}.detailcard .bd{position:relative}.detail-close{position:absolute;top:10px;right:10px;width:32px;height:32px;border:1px solid var(--line);border-radius:9px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--muted);cursor:pointer;padding:0}.detail-close:hover{background:var(--bg)}.detail-close:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.tbl tbody tr.row-open{cursor:pointer}.matrix-scroll{overflow:auto;max-height:calc(100vh - 230px);-webkit-overflow-scrolling:touch}.matrix-scroll>table{margin:0}.att{border-collapse:separate;border-spacing:0;font-size:11px;table-layout:auto;min-width:max-content}.att th,.att td{border:1px solid var(--line);text-align:center;padding:0;height:38px;min-width:28px}.att thead th{background:#fbfcfe;font-weight:700;color:var(--muted);font-size:10px;position:sticky;top:0;z-index:2}.att th.nmcol,.att td.nmcol{width:170px;min-width:170px;text-align:left;padding:0 10px;position:sticky;left:0;background:#fff;z-index:3}.att thead th.nmcol{background:#fbfcfe;z-index:4}.att th.sat{color:#2563eb}.att th.sun{color:#dc2626}.att td.sat{background:#f6f9ff}.att td.sun{background:#fdf6f6}.att .nm{font-size:12px;font-weight:700}.att .nm small{display:block;color:var(--muted);font-weight:500;font-size:10px}.cellv{display:inline-flex;align-items:center;justify-content:center;width:24px;height:24px;border-radius:7px;font-size:10px;font-weight:800;font-family:var(--font-num)}.v-ok{background:var(--ok50);color:var(--ok)}.v-ab{background:var(--warn50);color:var(--warn)}.v-hol{background:#eef1f5;color:#94a3b3}.v-wait{background:var(--amber50);color:var(--amber)}.v-no{background:#fff;color:var(--warn);border:1px dashed var(--warn)}.v-wk{background:var(--teal50);color:var(--teal)}.leg{display:flex;gap:14px;font-size:11.5px;color:var(--muted);font-weight:600;margin-bottom:12px;flex-wrap:wrap}.leg span{display:flex;align-items:center;gap:6px}#permissions-view .matrix-scroll .tbl thead th:first-child{left:0;z-index:3}#permissions-view .matrix-scroll .tbl tbody td:first-child{position:sticky;left:0;background:#fff;z-index:1}#permissions-view .matrix-scroll .tbl tbody tr:hover td:first-child{background:#fafcfe}#permissions-view .perm-matrix{min-width:max-content;border-collapse:separate;border-spacing:0}#permissions-view .perm-matrix td.perm-cell,#permissions-view .perm-matrix th.perm-rolehead{text-align:center;padding-left:6px;padding-right:6px}#permissions-view .perm-matrix td.perm-cell{border-bottom:1px solid var(--line)}#permissions-view .perm-no{color:#c2ccd6;font-weight:700}#permissions-view .perm-matrix td.perm-resname,#permissions-view .perm-matrix th.perm-corner{text-align:left;white-space:nowrap;min-width:128px}#permissions-view .perm-matrix td.perm-resname{font-weight:600;background:#fff}#permissions-view .matrix-scroll .perm-matrix thead th{position:sticky;background:#fbfcfe}#permissions-view .matrix-scroll .perm-matrix tr.perm-cat-row th{top:0;z-index:2;font-size:10.5px;letter-spacing:.04em;font-weight:800;color:var(--muted);padding-top:5px;padding-bottom:5px;text-align:center;border-bottom:1px solid var(--line)}#permissions-view .matrix-scroll .perm-matrix tr:not(.perm-cat-row) th.perm-rolehead{top:26px;z-index:2}#permissions-view .matrix-scroll .perm-matrix th.perm-corner{left:0;z-index:4}#permissions-view .matrix-scroll .perm-matrix tr.perm-cat-row th.perm-corner{top:0}#permissions-view .matrix-scroll .perm-matrix tr:not(.perm-cat-row) th.perm-corner{top:26px}#permissions-view .matrix-scroll .perm-matrix tbody td.perm-resname{position:sticky;left:0;z-index:1}#permissions-view .perm-matrix .perm-grp,#permissions-view .perm-matrix th.perm-cathead{border-left:2px solid var(--line)}#permissions-view .perm-matrix th.perm-cathead.perm-cat-mgmt{box-shadow:inset 0 -2px 0 var(--teal)}#permissions-view .perm-matrix th.perm-cathead.perm-cat-worker{box-shadow:inset 0 -2px 0 var(--amber)}#permissions-view .perm-matrix th.perm-cathead.perm-cat-operator{box-shadow:inset 0 -2px 0 var(--violet)}#permissions-view .perm-matrix td.perm-cat-worker,#permissions-view .perm-matrix th.perm-rolehead.perm-cat-worker{background:color-mix(in srgb,var(--amber50) 28%,#fff)}#permissions-view .perm-matrix tbody tr:hover td.perm-cat-worker{background:color-mix(in srgb,var(--amber50) 40%,#fff)}.leg .leg-sep{width:1px;align-self:stretch;background:var(--line);margin:0 2px}.leg .perm-catdot{width:11px;height:11px;border-radius:3px;display:inline-block}.leg .perm-cat-mgmt{background:var(--teal)}.leg .perm-cat-worker{background:var(--amber)}.leg .perm-no{color:#c2ccd6;font-weight:700}.tg{width:36px;height:20px;border-radius:11px;background:var(--teal);position:relative;display:inline-block;border:none;padding:0;cursor:pointer;vertical-align:middle}.tg:after{content:"";position:absolute;width:16px;height:16px;border-radius:50%;background:#fff;top:2px;right:2px}.tg.off{background:#cbd5e1}.tg.off:after{right:auto;left:2px}.tg:disabled{opacity:.55;cursor:default}.tg:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.tg:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:44px;height:44px;min-width:44px;min-height:44px}#board-view{display:flex;flex-direction:column;min-height:0;height:100%;gap:0}.board-region{flex:1;min-height:0;display:flex;flex-direction:column}.cal-nav{display:flex;align-items:center;gap:10px;margin:0 0 14px;flex-wrap:wrap;position:sticky;top:0;z-index:20;background:var(--bg);padding-top:2px;padding-bottom:8px}.cal-nav .sp{flex:1}.cal-nav .navbtn{width:30px;height:30px;border:1px solid var(--line);border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;cursor:pointer;color:var(--muted)}.cal-nav .curm{font-weight:800;font-size:15px;min-width:120px;text-align:center}.cal-nav .navbtn.navbtn-lab{width:auto;min-width:30px;gap:3px;padding:0 9px;font-weight:700;font-size:12.5px;color:var(--ink)}.cal-nav .navbtn.navbtn-lab .navbtn-lb{white-space:nowrap}.seg.seg-ico button{display:inline-flex;align-items:center;gap:5px;white-space:nowrap}.navbtn.week-col-add{width:auto;gap:3px;padding:0 7px;font-size:11.5px;font-weight:700;color:var(--teal)}.navbtn.week-col-add .week-col-add-lb{white-space:nowrap}.cal-legend{display:flex;align-items:center;gap:16px;font-size:11.5px;font-weight:700;color:var(--muted);margin-bottom:8px}.cal-legend .cl-item{display:inline-flex;align-items:center;gap:6px}.cal-legend .cl-sw{width:10px;height:10px;border-radius:3px}.cal-legend .cl-sw.ok{background:var(--ok)}.cal-legend .cl-sw.bad{background:var(--warn)}.month-region{gap:0}.month-region .cal-grid{flex:1;min-height:0;grid-auto-rows:1fr;overflow:auto}.board-skeleton{flex:1;min-height:0;display:grid;grid-template-columns:repeat(7,1fr);grid-auto-rows:64px;gap:8px;padding:4px 0}.sk-row{grid-column:1 / -1;height:48px;border-radius:10px;background:linear-gradient(90deg,#eef2f6 25%,#f6f9fc 37%,#eef2f6 63%);background-size:400% 100%;animation:sk-pulse 1.2s ease-in-out infinite}@keyframes sk-pulse{0%{background-position:100% 0}to{background-position:-100% 0}}.cal-grid{display:grid;grid-template-columns:repeat(7,1fr);background:var(--line);border:1px solid var(--line);border-radius:12px;overflow:hidden;gap:1px}.cal-grid .wd{background:#fbfcfe;text-align:center;font-size:11.5px;font-weight:700;color:var(--muted);padding:8px 0}.cal-grid .wd.sat{color:#2563eb}.cal-grid .wd.sun{color:#dc2626}.cal-cell{background:#fff;min-height:96px;padding:6px 7px;cursor:pointer;display:flex;flex-direction:column;gap:3px;text-align:left;border:0;font-family:inherit}.cal-cell:hover{background:#fafcfe}.cal-cell.out{background:#f8fafc;color:#aab6c4}.cal-cell.today{outline:2px solid var(--teal);outline-offset:-2px}.cal-cell .cd{font-size:12.5px;font-weight:700;font-family:var(--font-num);display:flex;align-items:center;gap:5px}.cal-cell .cnt{font-size:11px;color:var(--muted);font-weight:600}.cal-cell .sm{font-size:11px;font-weight:700}.cal-cell .sm.ok{color:var(--ok)}.cal-cell .sm.bad{color:var(--warn)}.cal-bars{display:flex;flex-wrap:wrap;gap:2px;margin-top:auto}.cal-bar{height:4px;flex:1 1 14px;min-width:14px;max-width:30px;border-radius:2px;background:var(--ok)}.cal-bar.bad{background:var(--warn)}.day-wrap{display:flex;flex-direction:column;min-height:0;height:100%;overflow:hidden}.day-wrap>.day-scroll{flex:1;min-height:0;overflow-y:auto;padding-right:4px}.day-chips{display:flex;gap:8px;flex-wrap:wrap;margin-bottom:14px}.shiftblk{margin-bottom:18px}.shiftblk .sh{font-size:13px;font-weight:800;margin-bottom:9px;display:flex;align-items:center;gap:8px}.shiftblk .sh small{color:var(--muted);font-weight:600}.taskgrid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:12px}.tcard{border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px;border-top:3px solid var(--ok)}.tcard.short{border-top-color:var(--warn)}.tcard.drop{outline:2px dashed var(--teal);outline-offset:2px;background:var(--teal50)}.tcard .tt{font-size:13.5px;font-weight:700;display:flex;align-items:center;gap:8px;margin-bottom:8px}.tcard .tt .badge{margin-left:auto}.wchips{display:flex;flex-wrap:wrap;gap:6px;margin-bottom:8px;min-height:26px}.wchip{display:inline-flex;align-items:center;gap:5px;font-size:11px;font-weight:700;background:var(--bg);border:1px solid var(--line);border-radius:7px;padding:3px 7px;color:var(--ink)}.wchip.lead{background:var(--amber50);border-color:#f3d9ad;color:var(--amber)}.wchip.vend{background:var(--teal50);border-color:var(--teal100);color:var(--teal)}.dropz{font-size:11px;color:var(--muted);text-align:center;border:1px dashed var(--line);border-radius:8px;padding:6px;font-weight:600}.tcard.short .dropz{color:var(--warn);border-color:#f7c9c5}.pool{border:1px solid var(--line);border-radius:12px;background:#fff;padding:12px;display:flex;flex-direction:column;min-height:0;max-height:100%}.pool h4{font-size:13px;font-weight:800;margin-bottom:10px;display:flex;align-items:center;gap:7px}.pool-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column}.shortage-rail h4 .shortage-rail-close{width:24px;height:24px;flex:0 0 24px}.shortage-list{flex:1;min-height:0;overflow-y:auto;display:flex;flex-direction:column;gap:9px}.shortage-site{border:1px solid var(--line);border-radius:10px;background:#fff;padding:7px 8px}.shortage-site-hd{display:flex;align-items:center;gap:6px;margin-bottom:6px}.shortage-site-name{display:flex;align-items:center;gap:4px;font-size:12.5px;font-weight:800;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.shortage-site-area{font-size:10.5px;color:var(--muted);font-weight:600}.shortage-site-total{font-size:10.5px}.shortage-row{display:flex;align-items:center;gap:6px;width:100%;text-align:left;border:1px solid var(--line);border-radius:8px;background:#fff;padding:6px 8px;margin-top:5px;cursor:pointer;font-family:inherit}.shortage-row:first-of-type{margin-top:0}.shortage-row:hover{background:var(--teal50);border-color:var(--teal)}.shortage-row:focus-visible{outline:2px solid var(--teal);outline-offset:1px}.shortage-row-shift{display:flex;align-items:center;gap:3px;font-size:11px;font-weight:700;color:var(--ink)}.shortage-row-time,.shortage-row-cap{font-size:10.5px;color:var(--muted)}.shortage-row-n{font-size:11px;font-weight:800;color:var(--warn);white-space:nowrap}.comp-staged{color:var(--amber);font-weight:700;font-size:.92em}.comp-resid{font-weight:800;margin-left:1px}.comp-sub{color:var(--muted);font-weight:600;font-size:.85em;margin-left:2px}.shortage-row-comp{display:inline-flex;align-items:baseline;gap:0;white-space:nowrap}.shortage-row.comp-staged-fill{border-color:#e6b566;background:var(--amber50)}.shortage-row.comp-staged-fill .shortage-row-n .comp-resid{color:var(--amber)}.shortage-site-total.b-tl{color:var(--amber);background:var(--amber50);border:1px solid #e6b566}.week-shortage-days{display:flex;flex-wrap:wrap;gap:5px;margin-top:5px}.week-shortage-day{display:inline-flex;align-items:center;gap:4px;border:1px solid #f7c9c5;border-radius:7px;background:var(--warn50);padding:3px 7px;cursor:pointer;font-family:inherit;font-size:11px;font-weight:800;color:var(--warn)}.week-shortage-day:hover{filter:brightness(.97)}.week-shortage-day:focus-visible{outline:2px solid var(--teal);outline-offset:1px}.week-shortage-day.comp-staged-fill{border-color:#e6b566;background:var(--amber50);color:var(--amber)}.week-shortage-day .wsd-date{font-family:var(--font-num);color:var(--ink);font-weight:700}.week-shortage-day .wsd-n{white-space:nowrap}.cell-flash{animation:cell-flash 1.4s ease-out}@keyframes cell-flash{0%,40%{box-shadow:0 0 0 2px var(--teal),0 0 0 6px var(--teal50)}to{box-shadow:0 0 0 0 transparent}}.poolitem{display:flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:9px;padding:7px 9px;margin-bottom:7px;cursor:grab;background:#fff}.poolitem:hover{background:#fafcfe}.poolitem.pick{outline:2px solid var(--teal);outline-offset:-1px;background:var(--teal50)}.poolitem .who{font-size:12.5px;font-weight:700}.poolitem .who small{display:block;color:var(--muted);font-weight:500;font-size:10.5px}.poolitem .sp{flex:1}.draft-bar{display:flex;align-items:center;gap:10px;background:var(--amber50);border:1px solid #f3d9ad;border-radius:10px;padding:8px 12px;margin-bottom:10px;flex-wrap:wrap}.draft-bar-lead{display:flex;align-items:center;gap:6px;font-size:13px;font-weight:800;color:var(--amber)}.draft-bar-lead strong{font-size:15px}.draft-bar .btn.sm{padding:5px 11px}.site-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(290px,1fr));gap:12px}.site-cell{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden;display:flex;flex-direction:column}.site-cell.short{box-shadow:inset 3px 0 0 var(--warn)}.site-cell-hd{display:flex;align-items:center;gap:7px;padding:9px 11px;background:#fafcfe;border-bottom:1px solid var(--line)}.site-cell-name{display:flex;align-items:center;gap:6px;font-size:13.5px;font-weight:800;color:var(--ink);min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.site-cell-name svg{color:var(--teal);flex:0 0 auto}.site-cell-area{font-size:11px;font-weight:600;color:var(--muted);background:var(--bg);border-radius:6px;padding:1px 6px;flex:0 0 auto}.site-cell-total{flex:0 0 auto;font-family:var(--font-num)}.site-shifts{display:flex;flex-direction:column}.shift-row{border-top:1px solid var(--line);padding:8px 11px;cursor:pointer;background:#fff}.site-shifts>.shift-row:first-child{border-top:0}.shift-row:hover{background:#fafcfe}.shift-row.short{background:linear-gradient(0deg,var(--warn50),transparent 40%)}.shift-row.drop{outline:2px dashed var(--teal);outline-offset:-2px;background:var(--teal50)}.shift-row.open{box-shadow:inset 0 0 0 1.5px var(--teal)}.shift-row.assignable{outline:1.5px dashed var(--teal);outline-offset:-2px;cursor:copy}.shift-row-hd{display:flex;align-items:center;gap:7px;margin-bottom:6px}.shift-tag{display:inline-flex;align-items:center;gap:4px;font-size:11px;font-weight:800;color:var(--navy);background:#eef1f5;border-radius:6px;padding:2px 7px;flex:0 0 auto}.shift-tag svg{color:var(--teal)}.shift-tag[data-shift=night]{background:#23304a;color:#dbe6f5}.shift-tag[data-shift=night] svg{color:#9db8e0}.shift-time{font-size:11px;font-weight:600;color:var(--muted);font-family:var(--font-num)}.shift-cap{flex:0 0 auto;font-family:var(--font-num)}.shift-short{font-size:10.5px;font-weight:800;color:var(--warn);background:var(--warn50);border:1px solid #f7c9c5;border-radius:6px;padding:1px 6px;flex:0 0 auto}.shift-short.shift-comp{display:inline-flex;align-items:baseline;gap:0}.shift-short.comp-staged-fill{color:var(--amber);background:var(--amber50);border-color:#e6b566}.dropz-inline.staged-full{color:var(--amber);border-color:#e6b566;background:var(--amber50);font-weight:800}.shift-row .wchips{min-height:0;margin-bottom:0}.shift-row-foot{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:6px}.shift-row-foot:empty{display:none}.dropz-inline{font-size:10.5px;font-weight:700;color:var(--muted);border:1px dashed var(--line);border-radius:6px;padding:3px 7px}.shift-row.short .dropz-inline{color:var(--warn);border-color:#f7c9c5}.wchip.staged{background:var(--amber50);border:1px dashed #e6b566;color:var(--amber);font-style:italic}.staged-x{border:0;background:transparent;color:var(--amber);font-weight:900;cursor:pointer;padding:0 0 0 3px;font-size:13px;line-height:1}.staged-x:hover{color:var(--warn)}.row-commit{display:inline-flex;gap:6px;margin-left:auto}.row-commit-ok,.row-commit-cancel{border:1px solid var(--line);background:#fff;border-radius:7px;font-size:11px;font-weight:800;cursor:pointer;padding:3px 9px;font-family:inherit}.row-commit-ok{background:var(--teal);border-color:var(--teal);color:#fff}.row-commit-ok:disabled{opacity:.55;cursor:default}.row-commit-cancel{color:var(--muted)}.row-commit-cancel:hover{color:var(--warn);border-color:#f7c9c5}.rail-group{margin-bottom:8px}.rail-group-hd{display:flex;align-items:center;gap:5px;font-size:11px;font-weight:800;color:var(--navy);text-transform:none;padding:3px 2px 5px;position:sticky;top:0;background:#fff;z-index:1}.rail-group-hd svg{color:var(--teal);flex:0 0 auto}.rail-group-hd.free{color:var(--muted)}.rail-group-hd.free svg{color:var(--muted)}.rail-group-n{margin-left:auto;font-family:var(--font-num);font-weight:700;color:var(--muted);background:var(--bg);border-radius:6px;padding:0 6px;font-size:10.5px}.load-badge{font-size:11px;font-weight:800;font-family:var(--font-num);color:var(--navy);background:#eef1f5;border-radius:6px;padding:1px 6px;flex:0 0 auto}.load-badge.has-staged{color:var(--amber);background:var(--amber50)}.load-badge.free{color:var(--ok);background:#e8f6ef;font-family:inherit}.avail-badge{font-size:10px;font-weight:700;border-radius:6px;padding:1px 6px;flex:0 0 auto;white-space:nowrap;color:var(--teal);background:var(--teal50)}.avail-badge[data-avail=off]{color:var(--slate);background:#eef1f5}.avail-badge[data-fit=warn]{color:var(--amber);background:var(--amber50)}.wchip.more{cursor:pointer;font-family:var(--font-num);color:var(--navy);background:#eef1f5;border-color:var(--line)}.wchip.more:hover{background:#e3e9f1;border-color:var(--slate)}.wchip.more:focus-visible{outline:2px solid var(--teal);outline-offset:1px}.wchip.more.open{font-family:inherit;color:var(--muted)}.shift-row[data-fill=full]{box-shadow:inset 3px 0 0 var(--ok)}@media (max-width:768px){.site-grid{grid-template-columns:1fr}.draft-bar{position:sticky;top:0;z-index:5}}.mw-wrap{display:flex;min-height:100vh;background:linear-gradient(120deg,#eef3f8,#f4f6f9)}.mw-aside{flex:1;padding:54px 56px;display:none;flex-direction:column;gap:18px}@media (min-width:900px){.mw-aside{display:flex}}.mw-aside .wm{font-size:26px;font-weight:800}.mw-aside .wm b{color:var(--navy)}.mw-aside .wm i{color:var(--teal);font-style:normal}.mw-h{font-size:30px;font-weight:800;line-height:1.5;color:var(--ink);margin-top:10px}.mw-sub{font-size:14px;color:var(--muted);line-height:1.9;max-width:420px}.mw-feat{display:flex;flex-direction:column;gap:12px;margin-top:8px}.mw-feat span{display:flex;align-items:center;gap:9px;font-size:13px;font-weight:600;color:#334}.mw-feat span svg{color:var(--teal);width:16px;height:16px;flex:0 0 16px}.phone{width:380px;margin:auto;background:var(--navy);border-radius:30px;padding:10px;box-shadow:0 24px 60px #05376547;display:flex;flex-direction:column;min-height:720px;max-height:92vh}.phone-top{background:var(--navy);color:#fff;padding:14px 16px 12px;display:flex;align-items:center;justify-content:space-between}.phone-hi{font-size:16px;font-weight:800}.phone-date{font-size:12px;color:#bfe0ea;margin-top:2px}.phone-top .iconbtn{background:#ffffff1f;border:0;color:#fff;width:44px;height:44px;min-width:44px;min-height:44px}.phone-body{background:var(--bg);flex:1;overflow:auto;padding:16px;border-radius:4px}.phone-nav{background:#fff;display:flex;border-top:1px solid var(--line);border-radius:0 0 22px 22px}.phone-nav button{flex:1;border:0;background:transparent;padding:10px 0 12px;display:flex;flex-direction:column;align-items:center;gap:3px;font-size:11px;font-weight:700;color:var(--muted);font-family:inherit;cursor:pointer}.phone-nav button svg{width:19px;height:19px}.phone-nav button.on{color:var(--teal)}.mw-punch{width:100%;justify-content:center;display:flex;align-items:center;gap:9px;border:0;border-radius:14px;padding:16px;font-size:16px;font-weight:800;font-family:inherit;cursor:pointer;background:linear-gradient(135deg,var(--teal),#0892b6);color:#fff;box-shadow:0 6px 18px #007a9d52;margin-bottom:10px}.mw-punch.out{background:#fff;color:var(--navy);border:1px solid var(--line);box-shadow:none;font-size:14px;padding:12px}.mw-punch:disabled{opacity:.6}.mw-punch svg{width:18px;height:18px}.mw-ok{display:flex;align-items:center;gap:7px;background:var(--ok50);color:var(--ok);border:1px solid #b8e6d2;border-radius:10px;padding:9px 12px;font-size:12.5px;font-weight:700;margin-bottom:10px}.mw-ok svg{width:15px;height:15px}.mw-status{display:inline-flex;align-items:center;align-self:flex-start;background:var(--teal50);color:var(--teal);border:1px solid var(--teal100);border-radius:20px;padding:5px 13px;font-size:12.5px;font-weight:800;margin-bottom:10px}.mw-panel .btn{min-height:44px}.mw-sec{font-size:13px;font-weight:800;margin:14px 0 9px;color:var(--ink);display:flex;align-items:center;gap:6px}.mw-sec .num{color:var(--teal)}.mw-site{background:#fff;border:1px solid var(--line);border-radius:13px;padding:13px;margin-bottom:10px;border-left:3px solid var(--teal)}.mw-shift{display:flex;align-items:center;gap:8px;margin-bottom:7px}.mw-shift .num{font-size:11px;color:var(--muted);font-weight:700}.mw-name{font-size:15px;font-weight:800;margin-bottom:7px}.mw-row{display:flex;align-items:center;gap:8px;font-size:12.5px;color:#445;margin-top:5px}.mw-row svg{width:14px;height:14px;color:var(--muted);flex:0 0 14px}.mw-panel{text-align:center;padding:48px 16px;color:var(--muted);display:flex;flex-direction:column;align-items:center;gap:12px}.mw-panel svg{width:36px;height:36px;color:var(--teal)}.mw-panel p{font-size:14px;color:var(--ink);line-height:1.8}.notif-bell{position:relative}.notif-pop{position:absolute;top:44px;right:0;width:340px;max-height:440px;background:#fff;border:1px solid var(--line);border-radius:13px;box-shadow:0 16px 44px #05376533;z-index:50;overflow:hidden;display:flex;flex-direction:column}.notif-pop-hd{padding:12px 14px;border-bottom:1px solid var(--line);display:flex;align-items:center;font-size:14px}.notif-pop-hd .more{margin-left:auto;color:var(--teal);font-size:12px;font-weight:700}.notif-pop-bd{overflow:auto}.notif-item{display:flex;align-items:flex-start;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line)}.notif-item.unread{background:var(--teal50)}.notif-item .ni-main{flex:1;min-width:0}.ni-title{font-size:13px;font-weight:700;display:flex;align-items:center;gap:6px}.ni-dot{width:7px;height:7px;border-radius:50%;background:var(--teal);flex:0 0 7px}.ni-body{font-size:12px;color:var(--muted);margin-top:3px}.ni-time{font-size:11px;color:#aab6c4;margin-top:4px}.notif-read{padding:4px 9px;font-size:11px}.notif-pop{width:min(388px,calc(100vw - 16px))}@media (max-width:480px){.notif-pop{position:fixed;top:56px;right:8px;left:8px;width:auto;max-height:calc(100dvh - 72px)}}.notif-pop-hd .notif-readall{margin-left:10px;padding:3px 9px;font-size:11px;font-weight:700}.notif-item .ni-kind-ico{width:18px;height:18px;flex:0 0 18px;margin-top:1px}.ni-kind-ico.k-money{color:var(--ok)}.ni-kind-ico.k-warn{color:var(--amber)}.ni-kind-ico.k-info{color:var(--teal)}.notif-item{border-left:3px solid transparent}.notif-item.k-money{border-left-color:var(--ok)}.notif-item.k-warn{border-left-color:var(--amber)}.notif-item.k-info{border-left-color:var(--teal)}.notif-item[data-read="1"]{opacity:.74}.notif-item[data-read="1"] .ni-kind-ico{opacity:.7}.ni-title-txt{overflow:hidden;text-overflow:ellipsis}.ni-meta{display:flex;align-items:center;flex-wrap:wrap;gap:5px;margin-top:4px}.ni-meta .badge{font-size:10px;padding:1px 7px}.ni-link{font-size:11px;font-weight:700;color:var(--teal);margin-left:auto;white-space:nowrap}.notif-item.linkable{cursor:pointer}.notif-item.linkable:hover{background:var(--teal50)}.notif-item.linkable.unread:hover{background:var(--teal100)}.notif-item.linkable:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}.board-split{display:grid;grid-template-columns:230px minmax(0,1fr);gap:16px;align-items:stretch;min-height:0;overflow:hidden}.board-split.has-pool{grid-template-columns:230px minmax(0,1fr) 250px}.board-split:has(#board-detail){grid-template-columns:230px minmax(0,1fr) 300px}.board-split.has-pool:has(#board-detail){grid-template-columns:230px minmax(0,1fr) 250px 300px}.board-split:has(#board-shortage-rail){grid-template-columns:230px minmax(0,1fr) 240px}.board-split.has-pool:has(#board-shortage-rail){grid-template-columns:230px minmax(0,1fr) 250px 240px}.board-split:has(#board-shortage-rail):has(#board-detail){grid-template-columns:230px minmax(0,1fr) 240px 300px}.board-split.has-pool:has(#board-shortage-rail):has(#board-detail){grid-template-columns:230px minmax(0,1fr) 250px 240px 300px}.board-split:has(#board-week-shortage-rail){grid-template-columns:230px minmax(0,1fr) 240px}.board-split.has-pool:has(#board-week-shortage-rail){grid-template-columns:230px minmax(0,1fr) 250px 240px}.board-split:has(#board-week-shortage-rail):has(#board-detail){grid-template-columns:230px minmax(0,1fr) 240px 300px}.board-split.has-pool:has(#board-week-shortage-rail):has(#board-detail){grid-template-columns:230px minmax(0,1fr) 250px 240px 300px}.board-main{min-width:0;min-height:0;display:flex;flex-direction:column;overflow:hidden}.board-main>*{flex:1;min-height:0}.board-side{display:flex;flex-direction:column;gap:14px;min-height:0;max-height:100%;overflow-y:auto}.mini-cal{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px}.mini-cal .mc-hd{font-size:13px;font-weight:800;text-align:center;margin-bottom:8px}.mc-grid{display:grid;grid-template-columns:repeat(7,1fr);gap:2px}.mc-wd{font-size:10px;font-weight:700;color:var(--muted);text-align:center;padding-bottom:3px}.mc-wd.sat{color:#2563eb}.mc-wd.sun{color:#dc2626}.mc-cell{position:relative;aspect-ratio:1;border:0;background:transparent;border-radius:7px;font-size:11.5px;font-weight:600;color:var(--ink);cursor:pointer;display:flex;align-items:center;justify-content:center}.mc-cell:hover{background:var(--bg)}.mc-cell.out{color:#c2ccd6}.mc-cell.today{outline:1.5px solid var(--teal);outline-offset:-1px}.mc-cell.sel{background:var(--navy);color:#fff}.mc-dot{position:absolute;bottom:3px;width:4px;height:4px;border-radius:50%;background:var(--teal)}.mc-cell.sel .mc-dot{background:#fff}.side-flt{border:1px solid var(--line);border-radius:12px;background:#fff;padding:10px}.side-flt-hd{font-size:12px;font-weight:800;margin-bottom:8px;display:flex;align-items:center;justify-content:space-between}.side-flt-hd .lnk{border:0;background:transparent;color:var(--teal);font-size:11px;font-weight:700;cursor:pointer;font-family:inherit}.side-flt-list{display:flex;flex-direction:column;gap:5px;max-height:200px;overflow:auto}.side-flt-chips{display:flex;flex-wrap:wrap;gap:6px}.fchip.sm{padding:5px 9px;font-size:11.5px}.ck{display:flex;align-items:center;gap:7px;font-size:12px;font-weight:600;cursor:pointer}.ck input{accent-color:var(--teal)}.ck .dot{width:9px;height:9px;border-radius:3px;flex:0 0 9px}.ck .ck-lb{white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.fchip .dot{width:8px;height:8px;border-radius:50%}.week-view{display:flex;flex-direction:column;min-height:0;height:100%}.week-view>.cal-legend{flex:0 0 auto}.week-wrap{overflow:auto;border:1px solid var(--line);border-radius:12px;background:#fff;min-height:0;flex:1}.week-cols{display:grid;grid-auto-flow:column;grid-auto-columns:minmax(124px,1fr);min-width:100%;min-height:100%}.week-col{border-right:1px solid var(--line);min-width:0;display:flex;flex-direction:column;min-height:0}.week-col:last-child{border-right:0}.week-col.today{background:#fbfdff}.week-col-hd{padding:8px 8px 6px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fbfcfe;z-index:1;flex:0 0 auto}.week-col-hd.sat .week-col-date{color:#2563eb}.week-col-hd.sun .week-col-date{color:#dc2626}.week-col-date{border:0;background:transparent;font-size:15px;font-weight:800;cursor:pointer;font-family:var(--font-num);color:var(--ink)}.week-col-date small{font-size:11px;font-weight:600;color:var(--muted);font-family:inherit}.week-badges{display:flex;flex-wrap:wrap;gap:4px;margin-top:5px}.week-badge{display:inline-flex;align-items:center;gap:2px;font-size:10.5px;font-weight:700;font-family:var(--font-num);background:var(--teal50);color:var(--teal);border:1px solid var(--teal100);border-radius:6px;padding:1px 5px}.week-badge.warn{background:var(--warn50);color:var(--warn);border-color:#f7c9c5}.week-cards{display:flex;flex-direction:column;gap:6px;padding:8px;flex:1;min-height:0;overflow-y:auto;background:linear-gradient(#fff 30%,#fff0) 0 0 / 100% 12px no-repeat,linear-gradient(#fff0,#fff 70%) 0 100% / 100% 12px no-repeat,radial-gradient(farthest-side at 50% 100%,#0537651a,#05376500) 0 100% / 100% 6px no-repeat;background-attachment:local,local,scroll}.week-card{position:relative;text-align:left;border:1px solid var(--line);border-left:4px solid var(--ok);border-radius:9px;background:#fff;padding:8px 9px;cursor:pointer;font-family:inherit}.week-card:hover{background:#fafcfe}.week-card.short{box-shadow:inset 0 0 0 1px #f7c9c5}.week-card.drop{outline:2px dashed var(--teal);outline-offset:-1px;background:var(--teal50)}.week-card.assignable{outline:1.5px dashed var(--teal);outline-offset:-1px;cursor:copy}.week-card .assign-hint{display:block;margin-top:5px;font-size:10.5px;font-weight:800;color:var(--teal);background:var(--teal50);border:1px dashed var(--teal100);border-radius:6px;padding:2px 6px;text-align:center}.wc-time{font-size:11px;font-weight:700;color:var(--teal);font-family:var(--font-num)}.wc-area{font-size:10.5px;font-weight:600;color:var(--muted)}.wc-site{font-size:12.5px;font-weight:700;margin-top:1px}.wc-content{font-size:11px;color:var(--slate);margin-top:2px;line-height:1.4}.wc-badge{position:absolute;top:7px;right:7px}.tg-wrap{border:1px solid var(--line);border-radius:12px;background:#fff;overflow:hidden;display:flex;flex-direction:column;min-height:0;height:100%}.tg-toolbar{display:flex;align-items:center;gap:10px;padding:8px 12px;border-bottom:1px solid var(--line);flex:0 0 auto}.tg-scroll{overflow:auto;flex:1;min-height:0;display:flex;flex-direction:column;align-items:flex-start;background:linear-gradient(#fff 30%,#fff0) 0 0 / 100% 14px no-repeat,linear-gradient(#fff0,#fff 70%) 0 100% / 100% 14px no-repeat,radial-gradient(farthest-side at 50% 100%,#0537651f,#05376500) 0 100% / 100% 8px no-repeat,linear-gradient(to right,#fff 30%,#fff0) 0 0 / 14px 100% no-repeat,linear-gradient(to left,#fff 30%,#fff0) 100% 0 / 14px 100% no-repeat,radial-gradient(farthest-side at 100% 50%,#0537651f,#05376500) 100% 0 / 8px 100% no-repeat;background-attachment:local,local,scroll,local,local,scroll}.tg-body{display:flex;position:relative;width:max-content;min-width:100%;flex:1 0 auto}.tg-gutter{position:relative;flex:0 0 52px;border-right:1px solid var(--line)}.tg-hour{position:absolute;left:0;width:100%;font-size:10.5px;color:var(--muted);font-family:var(--font-num);padding-left:6px;transform:translateY(-6px)}.tg-lanes{position:relative;display:flex;min-width:0}.tg-line{position:absolute;left:0;right:0;height:1px;background:var(--line);z-index:0}.tg-now{position:absolute;left:0;right:0;height:2px;background:var(--warn);z-index:5}.tg-now:before{content:"";position:absolute;left:0;top:-3px;width:7px;height:7px;border-radius:50%;background:var(--warn)}.tg-lane{position:relative;flex:1 0 160px;min-width:160px;border-right:1px solid var(--line);display:flex;flex-direction:column}.tg-lane:last-child{border-right:0}.tg-lane-hd{position:sticky;top:0;background:#fbfcfe;border-bottom:1px solid var(--line);font-size:11.5px;font-weight:700;padding:5px 7px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;z-index:2}.tg-lane-body{position:relative;overflow:hidden;flex:1}.tg-bar{position:absolute;border:1px solid var(--line);border-left:4px solid var(--ok);border-radius:7px;padding:3px 5px;overflow:hidden;text-align:left;cursor:pointer;font-family:inherit;display:flex;flex-direction:column;gap:1px;z-index:1}.tg-bar:hover{filter:brightness(.98);z-index:3;box-shadow:0 2px 8px #05376526}.tg-bar-time{font-size:9.5px;font-weight:700;color:var(--slate);font-family:var(--font-num)}.tg-bar-site{font-size:11.5px;font-weight:700;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-bar-content{font-size:10px;color:var(--slate);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.tg-bar-chips{display:flex;flex-wrap:wrap;gap:3px;margin-top:1px}.tg-chip{display:inline-flex;align-items:center;gap:2px;font-size:9.5px;font-weight:700;background:#fff;border:1px solid var(--line);border-radius:5px;padding:0 4px;color:var(--ink)}.tg-chip.lead{background:var(--amber50);border-color:#f3d9ad;color:var(--amber)}.tg-chip.vend{background:var(--teal50);border-color:var(--teal100);color:var(--teal)}.tg-chip.ok{background:var(--ok50);border-color:#bce6d4;color:var(--ok)}.tg-chip.warn{background:var(--warn50);border-color:#f7c9c5;color:var(--warn)}.board-detail{border:1px solid var(--line);border-radius:12px;background:#fff;display:flex;flex-direction:column;min-height:0;max-height:100%;overflow:hidden}.bd-hd{display:flex;align-items:flex-start;gap:8px;padding:12px;border-bottom:1px solid var(--line);flex:0 0 auto}.bd-site{font-size:14px;font-weight:800}.bd-sub{font-size:11.5px;color:var(--muted);font-family:var(--font-num);margin-top:2px}.bd-hd .navbtn{margin-left:auto;flex:0 0 30px}.bd-body{padding:12px;display:flex;flex-direction:column;gap:9px;flex:1;min-height:0;overflow-y:auto}.bd-row{display:flex;align-items:center;gap:8px;font-size:12.5px}.bd-k{font-size:11px;font-weight:700;color:var(--muted);flex:0 0 64px}.bd-workers{border-top:1px solid var(--line);padding-top:9px}.bd-worker{display:flex;align-items:center;gap:8px;margin-bottom:6px}.bd-assign{border-top:1px solid var(--line);padding-top:10px}.bd-assign-row{display:flex;gap:6px;align-items:center}.bd-assign-sel{flex:1;min-width:0;padding:8px 9px;font-size:12.5px}.bd-assign-row .btn{flex:0 0 auto;white-space:nowrap}.bd-assign-row .btn:disabled{opacity:.55;cursor:default}.wchip .wname,.tg-chip .wname{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.wchip,.tg-chip{max-width:100%}.wtag{flex:0 0 auto;font-size:9px;font-weight:800;background:#0000000f;color:inherit;border-radius:4px;padding:0 4px;line-height:1.5}.wchip.lead .wtag,.tg-chip.lead .wtag{background:#b4530924}.wchip.vend .wtag,.tg-chip.vend .wtag{background:#007a9d24}.cal-cell:focus-visible,.week-card:focus-visible,.tg-bar:focus-visible,.tcard:focus-visible,.mc-cell:focus-visible{outline:2px solid var(--teal);outline-offset:-1px}.week-card.open,.tcard.open{outline:2px solid var(--navy);outline-offset:-1px;background:var(--teal50)}.tg-bar.open{outline:2px solid var(--navy);outline-offset:0;z-index:4;box-shadow:0 2px 10px #05376538}.tg-bar.drop{outline:2px dashed var(--teal);outline-offset:0;z-index:4;background:var(--teal50)!important}.tg-bar.assignable{outline:1.5px dashed var(--teal);outline-offset:0;z-index:3;cursor:copy}.tg-bar .assign-hint{font-size:9px;font-weight:800;color:var(--teal);margin-top:1px}.tg-picked-cue{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:var(--teal);background:var(--teal50);border:1px solid var(--teal100);border-radius:7px;padding:3px 9px}.board-note{margin:0 0 10px;font-size:12.5px;font-weight:700;color:var(--warn);background:var(--warn50);border:1px solid #f7c9c5;border-radius:9px;padding:8px 12px}.pool-search{margin-bottom:8px}.pool-search .inp{padding:7px 9px 7px 32px;font-size:12.5px}.pool-search svg{left:10px;width:14px;height:14px}.tap44{min-width:44px;min-height:44px}.bottom-nav,.nav-drawer,.nav-backdrop{display:none}.bottom-nav{position:fixed;left:0;right:0;bottom:0;z-index:55;background:var(--navy);border-top:1px solid rgba(255,255,255,.1);display:none;padding-bottom:env(safe-area-inset-bottom,0)}.bnav-item{flex:1 1 0;min-width:0;min-height:56px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;border:0;background:transparent;color:#92a8bf;font-family:inherit;font-size:10.5px;font-weight:700;cursor:pointer;padding:6px 2px}.bnav-item svg{width:21px;height:21px;flex:0 0 21px}.bnav-item span{max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bnav-item.on{color:#fff}.bnav-item.on svg{stroke:#5cc2db}.bnav-item:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}.nav-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#05223373;z-index:56}.nav-drawer{position:fixed;top:0;left:0;bottom:0;width:82vw;max-width:320px;z-index:57;background:var(--navy);color:#fff;display:flex;flex-direction:column;box-shadow:2px 0 18px #0537654d;animation:nav-drawer-in .18s ease-out;overflow:hidden}@keyframes nav-drawer-in{0%{transform:translate(-100%)}to{transform:translate(0)}}.nav-drawer-hd{display:flex;align-items:center;justify-content:space-between;padding:14px 14px 12px;border-bottom:1px solid rgba(255,255,255,.12);flex:0 0 auto}.nav-drawer-logo{display:flex;align-items:center;gap:9px;font-size:15px;font-weight:800;color:#fff}.nav-drawer-hd .detail-close{position:static;background:#ffffff1f;border:0;color:#fff}.nav-drawer-list{flex:1 1 auto;min-height:0;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:2px}.nav-drawer-group{display:flex;flex-direction:column;gap:2px}.nav-drawer-group+.nav-drawer-group{margin-top:6px;padding-top:6px;border-top:1px solid rgba(255,255,255,.1)}.nav-drawer-group-hd{font-size:11px;font-weight:800;color:#8fa6bd;padding:4px 12px 2px;text-transform:none}.dnav-item{display:flex;align-items:center;gap:12px;min-height:48px;border:0;background:transparent;color:#c3d3e3;font-family:inherit;font-size:14px;font-weight:700;text-align:left;border-radius:10px;padding:10px 12px;cursor:pointer}.dnav-item svg{width:20px;height:20px;flex:0 0 20px}.dnav-item.on{background:#ffffff21;color:#fff}.dnav-item.on svg{stroke:#5cc2db}.dnav-item:hover{background:#ffffff12}.dnav-item:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}@media (max-width:768px){.top{gap:8px;padding:0 12px}.top .tt{font-size:14px;gap:6px;min-width:0;flex:1 1 auto;overflow:hidden}.top .tt .i.lg{flex:0 0 auto}.top .tt .tt-txt{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.top .sp{flex:0 0 auto}.global-search{flex:1 1 120px;min-width:96px}.gs-input{padding:6px 9px}.gs-input input{font-size:13px}.search-result{padding:11px 10px}.top .company{padding:5px 8px;font-size:11px;max-width:34vw;overflow:hidden;white-space:nowrap}.top .company #company-id{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.top .iconbtn,.notif-bell .iconbtn{width:44px;height:44px;min-width:44px;min-height:44px;flex:0 0 44px}.top .avatar{width:44px;height:44px;flex:0 0 44px}.top .btn.sm{padding:0 10px;font-size:11px;white-space:nowrap;flex:0 0 auto;min-height:44px}.rail{display:none}.bottom-nav{display:flex}.app.has-bottom-nav .content{padding-bottom:calc(70px + env(safe-area-inset-bottom,0))}.content{padding:14px 12px}.tbl-wrap{-webkit-overflow-scrolling:touch}.tbl-wrap>.tbl{min-width:560px}.tbl-wrap>.tbl td,.tbl-wrap>.tbl th{white-space:nowrap}.home-kpis,.kpis.cols4{grid-template-columns:repeat(2,1fr)}.mypage-grid,.mypage-fields,.mp-card-row,.doc-form-grid{grid-template-columns:1fr}.detailcard{position:fixed;top:0;right:0;bottom:0;left:0;z-index:58;margin:0;border-radius:0;border:0;overflow:auto;-webkit-overflow-scrolling:touch;animation:nav-drawer-in .16s ease-out}.detailcard>.bd{min-height:100%;padding:18px 16px 74px}.detailcard .detail-close{width:44px;height:44px}.seg{overflow-x:auto;-webkit-overflow-scrolling:touch}.seg button{white-space:nowrap;min-height:44px}.tabs{overflow-x:auto;-webkit-overflow-scrolling:touch}.tabs a,.tabs button{white-space:nowrap;flex:0 0 auto;min-height:44px;display:inline-flex;align-items:center}.card .bd label select,.card .bd label input{min-height:44px}.card .bd>.btn{min-height:44px}.doc-form-grid .inp,.scr-actions .inp,.scr-actions select,.doc-form-grid .btn,#doc-create .tabs button{min-height:44px}.tbl .btn,.scr-actions>.btn,.card .hd>.btn{min-height:44px}.card .hd button.more{min-height:44px;display:inline-flex;align-items:center}.iconbtn{min-width:44px;min-height:44px}.scr-actions{flex-wrap:wrap}.home-lists{grid-template-columns:1fr}#home-ai-banner{flex-wrap:wrap}#home-ai-banner>.btn{margin-left:0;white-space:nowrap;flex:0 0 auto}.notif-tbl,.tbl-wrap>.notif-tbl{min-width:0;width:100%}.notif-tbl thead{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);white-space:nowrap;border:0}.notif-tbl tbody{display:block}.notif-tbl tr.notif-row{display:block;border:1px solid var(--line);border-radius:12px;margin:0 0 10px;overflow:hidden}.notif-tbl tr.notif-row td{display:flex;align-items:center;gap:10px;padding:11px 14px;border-bottom:1px solid var(--line);white-space:normal;text-align:left!important}.notif-tbl tr.notif-row td:last-child{border-bottom:0}.notif-tbl td.notif-event{font-weight:700;background:#fbfcfe;font-size:13px;line-height:1.4}.notif-tbl td[data-label]:before{content:attr(data-label);font-size:12.5px;font-weight:700;color:var(--slate);flex:1 1 auto}.notif-tbl td.notif-inapp,.notif-tbl td.notif-email,.notif-tbl td.notif-digest{min-height:48px;justify-content:space-between}.notif-tbl td.notif-inapp .tg,.notif-tbl td.notif-email .tg,.notif-tbl td.notif-digest .tg{flex:0 0 auto;margin-left:auto}.notif-tbl td.notif-recipient{color:var(--muted);font-size:12px}.notif-tbl td.notif-recipient:before{color:var(--slate)}.cal-nav{gap:7px;padding-bottom:7px}.cal-nav .seg button{padding:8px 12px;font-size:12px;min-height:44px;display:inline-flex;align-items:center}.cal-nav .curm{min-width:0;font-size:13px}.cal-nav .sp{flex:1 1 100%;height:0}.cal-nav .btn.sm,.cal-nav .fchip{padding:9px 11px;font-size:11.5px;min-height:44px}.cal-nav .navbtn{width:44px;height:44px}.cal-nav .navbtn.navbtn-lab{width:auto;height:44px;padding:0 10px}.board-split.is-mobile{display:block;overflow:visible}.board-split.is-mobile>.board-main{display:flex;min-height:60vh}.board-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0522336b;z-index:60}.board-side-drawer{position:fixed;top:0;left:0;bottom:0;width:84vw;max-width:320px;z-index:61;background:var(--bg);border-right:1px solid var(--line);box-shadow:2px 0 16px #0537652e;display:flex;flex-direction:column;padding:12px;overflow-y:auto;animation:board-drawer-in .18s ease-out}.board-side-drawerhd{display:flex;align-items:center;justify-content:space-between;font-size:14px;font-weight:800;margin-bottom:10px;flex:0 0 auto}.board-side-drawer .board-side{overflow-y:visible;max-height:none}@keyframes board-drawer-in{0%{transform:translate(-100%)}to{transform:translate(0)}}#board-side-close,.board-detail .bd-hd .navbtn{width:44px;height:44px;flex:0 0 44px}.board-detail .inp,.board-detail .btn,.board-detail select{min-height:44px}.board-split.is-mobile #board-pool{position:fixed;left:0;right:0;bottom:0;z-index:62;max-height:62vh;border-radius:14px 14px 0 0;border:1px solid var(--line);box-shadow:0 -4px 18px #05376533;padding:12px}.board-split.is-mobile #board-detail,#task-create{position:fixed;top:0;right:0;bottom:0;left:0;z-index:64;max-height:none;border-radius:0;border:0;width:100%}.cal-cell{min-height:62px;padding:4px;gap:2px}.cal-cell .cd{font-size:11px;gap:3px}.cal-cell .cnt,.cal-cell .sm{font-size:10px}.cal-cell .cd .badge{display:none}.cal-grid .wd{font-size:10px;padding:5px 0}.cal-bars{gap:1px}.week-cols{grid-auto-columns:minmax(112px,1fr)}.tg-gutter{flex:0 0 44px}.tg-lane{flex:1 0 140px;min-width:140px}.tg-toolbar{gap:7px;padding:7px 9px;flex-wrap:wrap}}@media (max-width:480px){.home-kpis,.kpis.cols4,.grid2,.grid3{grid-template-columns:1fr}.bnav-item{font-size:9.5px;padding:6px 1px}.bnav-item svg{width:20px;height:20px}.top .company{max-width:26vw}.att th.nmcol,.att td.nmcol{width:118px;min-width:118px;padding:0 8px}.att .nm small{display:none}}@media (min-width:769px) and (max-width:1024px){.content{padding:16px}.home-kpis,.kpis.cols4{grid-template-columns:repeat(2,1fr)}}.tbl.compact thead th{padding:6px var(--cell-x);font-size:var(--fs-sub)}.tbl.compact tbody td{padding:var(--cell-y) var(--cell-x);font-size:var(--fs-body);height:var(--row-h-compact)}.tbl.compact tbody td .btn.sm,.tbl.compact tbody td button{min-height:var(--tap)}.tbl.zebra tbody tr:nth-child(2n){background:color-mix(in srgb,var(--bg) 55%,#fff)}.tbl.zebra tbody tr:hover{background:#fafcfe}.detailcard--slideover{position:fixed;top:56px;right:0;bottom:0;width:min(420px,92vw);margin-top:0;z-index:48;background:var(--card);border-left:1px solid var(--line);box-shadow:-12px 0 32px #05376524;overflow-y:auto;display:flex;flex-direction:column}.detailcard--slideover .bd{flex:1 1 auto}@media (max-width:768px){.detailcard--slideover{top:0;width:100vw;border-left:0}}@media (min-width:1025px) and (max-width:1366px){.detail-open .rail--wide{width:60px;flex:0 0 60px;padding-top:10px}.detail-open .rail--wide .sidenav-hd{justify-content:center;padding:2px 0 8px}.detail-open .rail--wide .sidenav-brand,.detail-open .rail--wide .sidenav-group-hd{display:none}.detail-open .rail--wide .sidenav-group-body{max-height:none}.detail-open .rail--wide .navitem{justify-content:center;padding:0;margin:0 8px}.detail-open .rail--wide .navitem-label,.detail-open .rail--wide .navitem-badge,.detail-open .rail--wide .sidenav-rollup{display:none}.detail-open .rail--wide .foot{align-self:center}}.detail-scrim{position:fixed;top:56px;left:0;right:0;bottom:0;z-index:47;background:#0f22332e}@media (max-width:768px){.detail-scrim{display:none}}.detailcard--slideover .detail-actions{margin-top:var(--sp-3);display:flex;gap:var(--sp-2);flex-wrap:wrap}@media (min-width:1025px) and (max-width:1366px){body.detail-slideover-open .rail--wide{width:60px;flex:0 0 60px;padding:10px 0 0}body.detail-slideover-open .rail--wide .sidenav-hd{justify-content:center;padding:2px 0 8px}body.detail-slideover-open .rail--wide .sidenav-brand,body.detail-slideover-open .rail--wide .sidenav-group-hd{display:none}body.detail-slideover-open .rail--wide .sidenav-group-body{max-height:none}body.detail-slideover-open .rail--wide .navitem{justify-content:center;padding:0;margin:0 8px}body.detail-slideover-open .rail--wide .navitem-label,body.detail-slideover-open .rail--wide .navitem-badge,body.detail-slideover-open .rail--wide .sidenav-rollup{display:none}}.stage-bar{position:sticky;bottom:0;z-index:6;display:flex;align-items:center;gap:var(--sp-3);padding:var(--sp-2) var(--sp-3);background:var(--card);border-top:1px solid var(--line);box-shadow:0 -6px 18px #05376514;min-height:var(--tap)}.stage-bar .stage-count{font-family:var(--font-num);font-variant-numeric:tabular-nums;font-weight:800;font-size:var(--fs-body);color:var(--navy)}.stage-bar .stage-actions{margin-left:auto;display:flex;gap:var(--sp-2)}.att-approve th.att-chkcol,.att-approve td.att-chkcol{width:40px;padding-left:var(--sp-2);padding-right:0}.att-approve .att-check{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap);min-height:var(--tap);cursor:pointer}.att-approve .att-row-check,.att-approve .att-select-all{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--teal)}.att-approve .att-row-check:disabled,.att-approve .att-select-all:disabled{cursor:default;opacity:.4}.att-approve .att-check:has(:disabled){cursor:default}.att-approve .att-row-check:focus-visible,.att-approve .att-select-all:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.att-approve tr.attendance-row.is-selected{background:color-mix(in srgb,var(--teal50) 60%,#fff)}.att-approve tr.attendance-row.is-selected:hover{background:var(--teal50)}.att-approve tr.attendance-row.is-selected td:first-child{box-shadow:inset 3px 0 0 var(--teal)}.att-approve .nm{font-size:var(--fs-body);font-weight:700;line-height:1.25}.att-approve .nm small{display:block;color:var(--muted);font-weight:500;font-size:10.5px}.att-approve td.att-anoms{display:flex;flex-wrap:wrap;gap:var(--sp-1);align-items:center}.att-approve .badge .i{width:13px;height:13px;flex:0 0 auto}.att-approve .att-pending-count{font-weight:700}.recon-tbl th.recon-chkcol,.recon-tbl td.recon-chkcol{width:40px;padding-left:var(--sp-2);padding-right:0}.recon-tbl .recon-check{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap);min-height:var(--tap);cursor:pointer}.recon-tbl .recon-row-check,.recon-tbl .recon-select-all{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--teal)}.recon-tbl .recon-row-check:disabled,.recon-tbl .recon-select-all:disabled{cursor:default;opacity:.4}.recon-tbl .recon-check:has(:disabled){cursor:default}.recon-tbl .recon-row-check:focus-visible,.recon-tbl .recon-select-all:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.recon-tbl tr.reconcile-row.is-selected{background:color-mix(in srgb,var(--teal50) 60%,#fff)}.recon-tbl tr.reconcile-row.is-selected:hover{background:var(--teal50)}.recon-tbl tr.reconcile-row.is-selected td.recon-chkcol{box-shadow:inset 3px 0 0 var(--teal)}.recon-tbl .recon-aging{margin-left:var(--sp-2);font-size:10.5px}.recon-tbl .recon-btn .i,.recon-card .stage-bar .btn .i{width:14px;height:14px;flex:0 0 auto}* 外注精算 確定テーブル（UI-D0 ★12・archetype A＋staging）— 追加クラスのみ（既存非破壊）。 * `.tbl.compact` を消費し、行頭チェック + select-all + `.stage-bar` で一括確定、行末でインライン確定。 * 経過措置控除（免税）は色＋テキストで明示。`.att-approve` のチェック/選択様式を踏襲（scope は別名）。 * ═══════════════════════════════════════════════════════════════════════════ */ .lg-note{color:var(--teal);background:var(--teal50);border:1px solid color-mix(in srgb,var(--teal) 30%,#fff);border-radius:9px;padding:9px 12px;font-size:12.5px;font-weight:600;margin-bottom:14px}.stl-tbl th.stl-chkcol,.stl-tbl td.stl-chkcol{width:40px;padding-left:var(--sp-2);padding-right:0}.stl-tbl .stl-check{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap);min-height:var(--tap);cursor:pointer}.stl-tbl .stl-row-check,.stl-tbl .stl-select-all{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--teal)}.stl-tbl .stl-row-check:disabled,.stl-tbl .stl-select-all:disabled{cursor:default;opacity:.4}.stl-tbl .stl-check:has(:disabled){cursor:default}.stl-tbl .stl-row-check:focus-visible,.stl-tbl .stl-select-all:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.stl-tbl tr.settlement-row.is-selected{background:color-mix(in srgb,var(--teal50) 60%,#fff)}.stl-tbl tr.settlement-row.is-selected:hover{background:var(--teal50)}.stl-tbl tr.settlement-row.is-selected td:first-child{box-shadow:inset 3px 0 0 var(--teal)}.stl-tbl .stl-deduction{font-weight:700}.stl-tbl .stl-ded-amt{color:var(--warn)}.stl-tbl .stl-ded-amt small{color:var(--muted);font-weight:600}.stl-tbl tfoot tr.stl-foot td{font-weight:800;border-top:2px solid var(--line)}.list-search{display:flex;align-items:center;gap:var(--sp-2);background:var(--bg);border:1px solid var(--line);border-radius:9px;padding:0 11px;min-height:var(--tap);color:var(--muted);min-width:260px;max-width:340px}.list-search:focus-within{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal50)}.list-search>svg{flex:0 0 auto;width:15px;height:15px}.list-search-inp{flex:1 1 auto;min-width:0;border:0;background:transparent;outline:none;font-family:inherit;font-size:var(--fs-body);color:var(--ink);padding:7px 0;min-height:var(--tap)}.list-search-inp::placeholder{color:var(--muted)}.list-search-inp::-webkit-search-cancel-button{cursor:pointer}.payroll-tbl th.payroll-chkcol,.payroll-tbl td.payroll-chkcol{width:40px;padding-left:var(--sp-2);padding-right:0}.payroll-tbl .payroll-check{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap);min-height:var(--tap);cursor:pointer}.payroll-tbl .payroll-row-check,.payroll-tbl .payroll-select-all{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--teal)}.payroll-tbl .payroll-row-check:disabled,.payroll-tbl .payroll-select-all:disabled{cursor:default;opacity:.4}.payroll-tbl .payroll-check:has(:disabled){cursor:default}.payroll-tbl .payroll-row-check:focus-visible,.payroll-tbl .payroll-select-all:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.payroll-tbl tr.payroll-row.is-selected{background:color-mix(in srgb,var(--teal50) 60%,#fff)}.payroll-tbl tr.payroll-row.is-selected:hover{background:var(--teal50)}.payroll-tbl tr.payroll-row.is-selected td.payroll-chkcol{box-shadow:inset 3px 0 0 var(--teal)}.payroll-card .stage-bar .btn .i{width:14px;height:14px;flex:0 0 auto}.payroll-detail-sums{display:grid;gap:2px;margin:var(--sp-2) 0;padding:var(--sp-2) 0;border-top:1px solid var(--line);border-bottom:1px solid var(--line)}.payroll-detail-sums .pd-sum{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-3);padding:3px 0}.payroll-detail-sums .pd-sum-l{color:var(--muted);font-size:var(--fs-sub)}.payroll-detail-sums .pd-sum-v{font-family:var(--font-num);font-variant-numeric:tabular-nums;font-size:var(--fs-body)}.payroll-detail-sums .pd-sum-net{margin-top:3px;padding-top:6px;border-top:1px dashed var(--line)}.payroll-detail-sums .pd-sum-net .pd-sum-l{color:var(--ink);font-weight:700;font-size:var(--fs-body)}.payroll-detail-sums .pd-sum-net .pd-sum-v{font-weight:800;font-size:15px;color:var(--navy)}.payroll-lines{list-style:none;margin:var(--sp-2) 0 0;padding:0;display:grid;gap:1px}.payroll-lines .pdetail-line{display:flex;align-items:baseline;justify-content:space-between;gap:var(--sp-3);padding:4px 0;border-bottom:1px solid var(--line);font-size:var(--fs-body)}.payroll-lines .pdetail-line:last-child{border-bottom:0}.payroll-lines .pl-cat{color:var(--muted);font-size:10.5px;margin-left:2px}.payroll-lines .pl-amt{font-family:var(--font-num);font-variant-numeric:tabular-nums}.ins-tbl thead .ins-grp{text-align:center;font-weight:800;color:var(--ink);border-bottom:1px solid var(--line)}.ins-tbl thead .ins-grp-health{background:color-mix(in srgb,var(--teal) 12%,#fff)}.ins-tbl thead .ins-grp-nursing{background:color-mix(in srgb,var(--amber) 14%,#fff)}.ins-tbl thead .ins-grp-pension{background:color-mix(in srgb,var(--violet) 12%,#fff)}.ins-tbl td.ins-std{font-weight:700;color:var(--navy)}.ins-tbl td.ins-rem{color:var(--muted);font-size:12px}.ins-tbl tbody tr.insurance-row[data-nursing="1"] td:nth-child(6),.ins-tbl tbody tr.insurance-row[data-nursing="1"] td:nth-child(7){background:color-mix(in srgb,var(--amber) 7%,transparent)}.ins-period,.ins-readonly{white-space:nowrap}.ins-legend{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-2)}.ins-nursing-key{white-space:nowrap}.atte-hd{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap}.atte-daynav{display:flex;align-items:center;gap:var(--sp-2)}.atte-daynav .btn.sm{min-height:var(--tap)}.atte-day{font-family:var(--font-num);font-variant-numeric:tabular-nums;font-weight:800;font-size:var(--fs-body);color:var(--navy);min-width:104px;text-align:center;letter-spacing:.02em}.atte-chev{font-weight:900;opacity:.7;line-height:1}.atte-counts{margin-left:auto;font-size:var(--fs-sub);color:var(--muted)}.atte-counts b{font-family:var(--font-num);font-variant-numeric:tabular-nums;color:var(--navy)}.atte-leg-hint{color:var(--teal);font-weight:700}.atte-leg-hint .i{width:14px;height:14px}.atte-grid .atte-namecell .nm{font-size:var(--fs-body);font-weight:700;line-height:1.25}.atte-grid .atte-namecell .nm small{display:block;color:var(--muted);font-weight:500;font-size:10.5px}.atte-grid .atte-time,.atte-grid .atte-break{font-variant-numeric:tabular-nums;color:var(--ink)}.atte-grid .atte-break{color:var(--muted)}.atte-grid .atte-work{font-variant-numeric:tabular-nums;font-weight:800;color:var(--navy)}.atte-grid tr.atte-row.is-unpunched{background:color-mix(in srgb,var(--warn) 4%,transparent)}.atte-grid .atte-unpunched{color:var(--warn);font-weight:700;font-size:var(--fs-sub);white-space:nowrap}.atte-grid .atte-unpunched .i{width:14px;height:14px;margin-right:4px;vertical-align:-2px}.atte-grid tr.atte-row.is-dirty td:first-child{box-shadow:inset 3px 0 0 var(--amber)}.atte-grid tr.atte-row.is-dirty{background:color-mix(in srgb,var(--amber50) 50%,#fff)}.atte-dirty-tag{margin-left:var(--sp-1)}.atte-grid .atte-status{white-space:nowrap}.atte-input{width:74px;max-width:100%;text-align:right;font-family:var(--font-num);font-variant-numeric:tabular-nums;font-size:var(--fs-body);font-weight:700;color:var(--ink);padding:6px 8px;min-height:var(--tap);border:1px solid var(--line);border-radius:8px;background:#fff}.atte-input-sm{width:58px}.atte-input:focus-visible{outline:2px solid var(--teal);outline-offset:1px;border-color:var(--teal)}.atte-grid .atte-edit .i,.atte-grid .atte-edit-done .i{width:14px;height:14px}.atte-stage .stage-count{color:var(--amber)}@media (max-width:768px){.atte-counts{margin-left:0}.atte-input{width:64px}.atte-input-sm{width:52px}}.ins-kpis{margin-bottom:14px}.audit-filters{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin-bottom:12px;flex:0 0 auto}.list-view>.audit-filters{flex:0 0 auto}.audit-filters .sp{flex:1 1 0}.audit-filters .audit-fld{display:inline-flex;align-items:center;gap:6px;font-size:11.5px;font-weight:700;color:var(--muted);white-space:nowrap}.audit-filters .audit-fld .inp{height:30px;padding:3px 8px;font-size:12.5px;font-weight:600;width:auto;min-width:92px}.audit-filters .audit-fld input[type=date].inp{min-width:140px}#audit-clear{flex:0 0 auto}.audit-high-count{margin-left:8px;font-size:10.5px}.audit-high-count .i{width:13px;height:13px;flex:0 0 auto}.audit-tbl .audit-op{gap:4px}.audit-tbl .audit-op .i{width:13px;height:13px;flex:0 0 auto}.audit-tbl .audit-at{color:var(--ink);white-space:nowrap;font-size:12px}.audit-tbl .audit-actor{white-space:nowrap}.audit-tbl .audit-actor-kind{display:inline-block;font-size:10px;font-weight:700;color:var(--slate);background:var(--bg);border-radius:5px;padding:1px 5px;margin-right:5px;vertical-align:1px}.audit-tbl .audit-action,.audit-tbl .audit-rid{font-family:var(--font-num);font-variant-numeric:tabular-nums;font-size:11.5px;color:var(--slate);background:color-mix(in srgb,var(--bg) 70%,#fff);border:1px solid var(--line);border-radius:5px;padding:1px 5px;white-space:nowrap}.audit-tbl .audit-res{white-space:nowrap}.audit-tbl .audit-reason{max-width:280px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.audit-tbl tbody tr.audit-row.sev-high td:first-child{box-shadow:inset 3px 0 0 var(--warn)}.audit-tbl tbody tr.audit-row:hover{background:#fafcfe}@media (max-width:768px){.audit-filters{gap:8px}.audit-filters .seg{flex:1 1 100%;order:-1}.audit-filters .sp{display:none}.audit-filters .audit-fld{flex:1 1 30%}.audit-filters .audit-fld .inp{min-height:44px;width:100%;flex:1 1 auto}.audit-filters #audit-clear{flex:1 1 100%}.audit-tbl .audit-reason{max-width:120px}}.broadcast-view{display:flex;flex-direction:column;min-height:0}.broadcast-toolbar{position:sticky;top:0;z-index:5;display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap;padding:var(--sp-2) 0;margin-bottom:var(--sp-3);background:var(--bg)}.broadcast-toolbar-info{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;margin:0;min-width:0}.broadcast-toolbar-info>.badge{flex:0 0 auto}.broadcast-unread-pill{font-size:11.5px}.broadcast-unread-pill .num{font-weight:800}.broadcast-toolbar>#broadcast-compose-toggle{margin-left:auto;flex:0 0 auto;min-height:var(--tap)}.broadcast-toolbar #broadcast-compose-toggle .i{flex:0 0 auto}.broadcast-compose-card{margin-bottom:var(--sp-4)}.broadcast-compose-body{padding:var(--sp-3);display:grid;gap:var(--sp-3)}.broadcast-targets-label{margin:0 0 var(--sp-2)}.broadcast-targets{display:flex;flex-wrap:wrap;gap:var(--sp-2)}.broadcast-target-chip{display:inline-flex;align-items:center;gap:var(--sp-1);cursor:pointer;-webkit-user-select:none;user-select:none;min-height:var(--tap);padding:4px 10px;font-size:var(--fs-sub);border:1px solid var(--line);background:#fff;border-radius:8px;color:var(--ink);font-weight:600}.broadcast-target-chip input{width:15px;height:15px;margin:0;accent-color:var(--teal);cursor:pointer}.broadcast-target-chip:hover{border-color:var(--teal100)}.broadcast-target-chip.on{background:var(--teal50);border-color:var(--teal100);color:var(--teal);font-weight:700}.broadcast-target-chip:focus-within{outline:2px solid var(--teal);outline-offset:1px}.broadcast-compose-actions{display:flex;gap:var(--sp-2);justify-content:flex-end}.broadcast-grid{display:grid;grid-template-columns:minmax(280px,1fr) minmax(320px,1.4fr);gap:var(--sp-4);align-items:start;min-height:0}.broadcast-list{display:flex;flex-direction:column}.broadcast-empty{padding:var(--sp-3)}.broadcast-row{display:block;width:100%;text-align:left;border:0;border-bottom:1px solid var(--line);background:transparent;padding:var(--cell-y) var(--cell-x);cursor:pointer;font-family:inherit;min-height:var(--tap);transition:background .08s}.broadcast-row:last-child{border-bottom:0}.broadcast-row:hover{background:#fafcfe}.broadcast-row:focus-visible{outline:2px solid var(--teal);outline-offset:-2px}.broadcast-row.on{background:var(--teal50)}.broadcast-row.is-unread{box-shadow:inset 3px 0 0 var(--warn)}.broadcast-row.is-unread.on{background:var(--teal50);box-shadow:inset 3px 0 0 var(--warn)}.broadcast-row-head{display:flex;align-items:center;gap:var(--sp-2);min-width:0}.broadcast-unread-badge{flex:0 0 auto;font-size:10.5px;padding:2px 7px}.broadcast-unread-badge .dot{width:6px;height:6px;border-radius:50%;background:var(--warn);flex:0 0 auto}.broadcast-row-title{font-size:var(--fs-body);font-weight:600;line-height:1.3;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;min-width:0}.broadcast-row.is-unread .broadcast-row-title{font-weight:800}.broadcast-row-meta{display:flex;align-items:center;gap:var(--sp-1);flex-wrap:wrap;font-size:11px;margin:3px 0 0;line-height:1.3}.broadcast-row-sep{color:var(--line)}.broadcast-row-audience{overflow:hidden;text-overflow:ellipsis;white-space:nowrap;max-width:14em}.broadcast-detail{align-self:start}.broadcast-detail-empty{padding:var(--sp-4)}.broadcast-detail-body-wrap{padding:var(--sp-3)}.broadcast-detail-meta{display:flex;align-items:center;gap:var(--sp-2);flex-wrap:wrap;font-size:11px;margin:0 0 var(--sp-3)}.broadcast-audience-badge{font-size:10.5px}.broadcast-detail-text{white-space:pre-wrap;font-size:var(--fs-body);line-height:1.55;color:var(--ink);margin-bottom:var(--sp-4)}.broadcast-comments-hd{margin:var(--sp-3) 0 var(--sp-2);font-size:13px;font-weight:700;color:var(--ink);padding-top:var(--sp-3);border-top:1px solid var(--line)}.broadcast-comments-hd .num{font-weight:800}.broadcast-comments{display:flex;flex-direction:column;gap:var(--sp-1)}.broadcast-comments-empty{padding:var(--sp-2) 0}.broadcast-comment{padding:var(--sp-2) 0 var(--sp-2) var(--sp-3);border-left:2px solid var(--teal100)}.broadcast-comment+.broadcast-comment{border-top:1px solid var(--line)}.broadcast-comment-meta{display:flex;align-items:center;gap:var(--sp-1);font-size:11px;margin-bottom:2px}.broadcast-comment-author{font-weight:700;color:var(--navy)}.broadcast-comment-text{white-space:pre-wrap;font-size:var(--fs-body);line-height:1.45;color:var(--ink)}.broadcast-comment-box{position:sticky;bottom:0;display:flex;gap:var(--sp-2);margin-top:var(--sp-3);padding-top:var(--sp-2);background:var(--card)}.broadcast-comment-box .inp{flex:1 1 auto;min-width:0}.broadcast-comment-box .btn{flex:0 0 auto;min-height:var(--tap)}@media (max-width:768px){.broadcast-grid{grid-template-columns:1fr}.broadcast-toolbar{position:static}.broadcast-toolbar>#broadcast-compose-toggle{min-height:44px}.broadcast-row{min-height:44px}.broadcast-row-audience{max-width:none}.broadcast-comment-box .btn,.broadcast-comment-box .inp{min-height:44px}}.rpt-band{display:flex;flex-wrap:wrap;align-items:center;gap:var(--sp-2);padding:0 16px 12px}.rpt-band .rpt-chip{display:inline-flex;align-items:center;gap:6px;font-size:12px;font-weight:700;border-radius:8px;padding:4px 10px;line-height:1.1}.rpt-band .rpt-chip .num{font-size:14px;font-weight:800}.rpt-band .rpt-chip.dn{background:var(--warn50);color:var(--warn)}.rpt-band .rpt-chip.am{background:var(--amber50);color:var(--amber)}.rpt-band .rpt-chip.up{background:var(--ok50);color:var(--ok)}.rpt-band .rpt-chip.mut{background:var(--bg);color:var(--slate)}.rpt-spark{width:160px;min-width:120px}.rpt-spark-rows{display:flex;flex-direction:column;gap:3px}.rpt-spark-track{position:relative;height:7px;border-radius:4px;background:var(--bg);overflow:hidden}.rpt-spark-fill{position:absolute;top:0;left:0;height:100%;border-radius:4px}.rpt-spark-fill.rev{background:var(--teal)}.rpt-spark-fill.gp{background:var(--ok)}.rpt-spark-fill.gp.neg{background:var(--warn)}.tbl tbody td.rpt-neg{color:var(--warn);font-weight:700}.tbl tbody tr.forecast-row[data-risk=critical] td:first-child{box-shadow:inset 3px 0 0 var(--warn)}.tbl tbody tr.forecast-row[data-risk=critical]{background:color-mix(in srgb,var(--warn50) 45%,#fff)}.tbl tbody tr.forecast-row[data-risk=critical]:hover{background:var(--warn50)}.tbl tbody tr.forecast-row[data-risk=warning] td:first-child{box-shadow:inset 3px 0 0 var(--amber)}.tbl tbody tr.forecast-row[data-risk=warning]:hover{background:var(--amber50)}#report-view .badge .i{width:13px;height:13px;flex:0 0 auto}@media (max-width:768px){.rpt-spark{display:none}}.shift-approve th.shift-chkcol,.shift-approve td.shift-chkcol{width:40px;padding-left:var(--sp-2);padding-right:0}.shift-approve .shift-check{display:inline-flex;align-items:center;justify-content:center;min-width:var(--tap);min-height:var(--tap);cursor:pointer}.shift-approve .shift-row-check,.shift-approve .shift-select-all{width:18px;height:18px;margin:0;cursor:pointer;accent-color:var(--teal)}.shift-approve .shift-row-check:disabled,.shift-approve .shift-select-all:disabled{cursor:default;opacity:.4}.shift-approve .shift-check:has(:disabled){cursor:default}.shift-approve .shift-row-check:focus-visible,.shift-approve .shift-select-all:focus-visible{outline:2px solid var(--teal);outline-offset:2px}.shift-approve tr.shift-row.is-selected{background:color-mix(in srgb,var(--teal50) 60%,#fff)}.shift-approve tr.shift-row.is-selected:hover{background:var(--teal50)}.shift-approve tr.shift-row.is-selected td:first-child{box-shadow:inset 3px 0 0 var(--teal)}.shift-approve .nm{font-size:var(--fs-body);font-weight:700;line-height:1.25}.shift-approve .nm small{display:block;color:var(--muted);font-weight:500;font-size:10.5px}.shift-approve .shift-approve .i,.shift-approve .stage-bar .btn .i{width:14px;height:14px;flex:0 0 auto}.pc-close-form{display:flex;gap:var(--sp-3);flex-wrap:wrap;align-items:flex-end}.pc-close-form .btn .i{width:14px;height:14px;flex:0 0 auto}.pc-gate{display:flex;align-items:center;gap:var(--sp-3);flex-wrap:wrap;padding:10px 16px;border-top:1px solid var(--line)}.pc-gate-open{background:var(--bg)}.pc-gate-closed{background:var(--warn50);border-top-color:color-mix(in srgb,var(--warn) 25%,var(--line))}.pc-gate-badge{flex:0 0 auto}.pc-gate-badge .i{width:13px;height:13px;flex:0 0 auto}.pc-gate-msg{font-size:12.5px;font-weight:600;color:var(--ink);flex:1 1 auto;min-width:0}.pc-gate-reopen{flex:0 0 auto;margin-left:auto}.pc-gate-reopen .i{width:13px;height:13px;flex:0 0 auto}.pc-tbl .pc-status{flex:0 0 auto}.pc-tbl .pc-status .i,.pc-tbl .pc-reopened-flag .i,.pc-tbl .pc-reopen .i{width:12.5px;height:12.5px;flex:0 0 auto}.pc-tbl .pc-reopened-flag{margin-left:var(--sp-2);font-size:10.5px}.pc-tbl tr.pc-row-reopened td:first-child{box-shadow:inset 3px 0 0 var(--amber)}.pc-tbl .pc-reopen{display:inline-flex;align-items:center;gap:5px}.leave-ledger .leave-name{font-weight:700;color:var(--ink);white-space:nowrap}.leave-ledger tr.leave-row.is-risk td:first-child{box-shadow:inset 3px 0 0 var(--warn)}.leave-ledger tr.leave-row.is-risk{background:color-mix(in srgb,var(--warn50) 45%,#fff)}.leave-ledger tr.leave-row.is-risk:hover{background:var(--warn50)}.leave-ledger tr.leave-row.is-warn{background:color-mix(in srgb,var(--amber50) 35%,#fff)}.leave-ledger tr.leave-row.is-warn:hover{background:var(--amber50)}.leave-ledger .leave-remaining .leave-remain-low{color:var(--warn);font-weight:700}.leave-ledger td.leave-status{white-space:nowrap}.leave-ledger .leave-status-badge .i{width:13px;height:13px;flex:0 0 auto}.leave-ledger .more .leave-hd-warn{margin-left:8px}.leave-ledger .more .leave-hd-warn .i{width:12px;height:12px}.leave-ledger .leave-note{opacity:.7}* OCR 取込（UI-D0 §7 #15・archetype D form/upload）— 追加クラスのみ（既存非破壊・canon 不変）。 * 2 段フロー: ①明確なアップロード affordance（アイコン＋文字・ドロップ） → ②密な確認/編集フォーム＋ * インライン検証（誤抽出対策）。人による確認ゲート（confirm）は維持。密度トークンを modifier で消費。 * 注: 別の UI 画面が先にマージされた場合、この末尾ブロックは app.css の rebase が要ることがある（想定内）。 * ═══════════════════════════════════════════════════════════════════════════ */ .ocr-view{align-items:flex-start}.ocr-card{flex:0 0 auto;width:100%;max-width:720px;overflow:visible}.ocr-view>.sub{flex:0 0 auto}.ocr-steps{display:flex;align-items:center;gap:var(--sp-2);list-style:none;margin:2px 0 14px;padding:0;flex:0 0 auto}.ocr-steps li{display:inline-flex;align-items:center;gap:7px;font-size:var(--fs-body);font-weight:700;color:var(--muted)}.ocr-steps li:after{content:"";width:22px;height:1px;background:var(--line);margin-left:var(--sp-1)}.ocr-steps li:last-child:after{display:none}.ocr-steps li.on{color:var(--navy)}.ocr-steps li.done{color:var(--ok)}.ocr-step-no{display:inline-flex;align-items:center;justify-content:center;width:22px;height:22px;border-radius:50%;font-size:12px;font-weight:800;font-family:var(--font-num);background:var(--bg);color:var(--muted);border:1px solid var(--line)}.ocr-steps li.on .ocr-step-no{background:var(--navy);color:#fff;border-color:var(--navy)}.ocr-steps li.done .ocr-step-no{background:var(--ok50);color:var(--ok);border-color:#bfe6cf}.ocr-step-no .i{width:14px;height:14px}.ocr-upload-bd{padding:14px 16px;display:grid;gap:14px}.ocr-opts{display:grid;grid-template-columns:1fr 1fr;gap:14px}.ocr-opts .field{margin-bottom:0}.ocr-drop{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:7px;text-align:center;min-height:148px;padding:22px 16px;border:2px dashed var(--line);border-radius:12px;background:var(--bg);cursor:pointer;color:var(--muted);transition:border-color .12s,background .12s}.ocr-drop:hover{border-color:var(--teal);background:color-mix(in srgb,var(--teal50) 55%,#fff)}.ocr-drop.is-drag{border-color:var(--teal);background:var(--teal50);color:var(--navy)}.ocr-drop.is-busy{cursor:default;opacity:.7}.ocr-drop:focus-within{border-color:var(--teal);box-shadow:0 0 0 2px var(--teal50)}.ocr-drop-icon{width:36px;height:36px;color:var(--teal)}.ocr-drop-title{font-size:14px;font-weight:700;color:var(--ink)}.ocr-drop-hint{font-size:var(--fs-sub);color:var(--muted)}.ocr-drop .ocr-req{color:var(--warn);font-weight:700;margin-left:4px}.ocr-drop-file{display:inline-flex;align-items:center;gap:6px;margin-top:4px;font-size:var(--fs-sub);font-weight:700;color:var(--navy);background:#fff;border:1px solid var(--line);border-radius:8px;padding:4px 9px}.ocr-drop-file .i{width:13px;height:13px;flex:0 0 auto}.ocr-file-hidden{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0 0 0 0);border:0}.ocr-review-bd{padding:14px 16px}.ocr-review-bd>.sub{margin-bottom:12px}.ocr-fields{display:grid;grid-template-columns:1fr 1fr;gap:var(--sp-3) var(--sp-4)}.ocr-field-row{margin-bottom:0}.ocr-field-row label{font-size:var(--fs-sub);margin-bottom:4px}.ocr-field.is-invalid{border-color:var(--warn);box-shadow:0 0 0 1px var(--warn)}.ocr-field.is-invalid:focus-visible{outline-color:var(--warn)}.ocr-field-err{display:flex;align-items:center;gap:5px;margin-top:5px;font-size:var(--fs-sub);font-weight:600;color:var(--warn)}.ocr-field-err .i{width:13px;height:13px;flex:0 0 auto}.ocr-actions{display:flex;gap:var(--sp-2);margin-top:16px}.ocr-actions .btn .i{width:15px;height:15px;flex:0 0 auto}.ocr-done-bd{padding:14px 16px;display:grid;gap:10px;justify-items:start}@media (max-width:768px){.ocr-opts,.ocr-fields{grid-template-columns:1fr}.ocr-actions{flex-direction:column;align-items:stretch}.ocr-actions .btn{min-height:44px;justify-content:center}}
