:root{--bg:#eef1f5;--surface:#fff;--surface-2:#f5f7fa;--line:#d3d9e2;--line-strong:#b7c0cd;--text:#1f2937;--muted:#5b6573;--brand:#1f3a5f;--brand-700:#16304f;--brand-300:#4f6f96;--brand-tint:#e8eef6;--focus:#2563eb;--ok:#1e7d46;--ok-bg:#e3f4ea;--warn:#b15c00;--warn-bg:#fbeedd;--danger:#c2261b;--danger-bg:#fbe5e3;--absent:#7a1f17;--absent-bg:#f4e2e0;--finished:#3b5a73;--finished-bg:#e7edf2;--neutral:#5b6573;--neutral-bg:#eceef1;--radius:10px;--radius-sm:7px;--radius-lg:14px;--shadow:0 1px 2px rgba(20,33,53,.06),0 2px 8px rgba(20,33,53,.07);--shadow-sm:0 1px 2px rgba(20,33,53,.08);--font:-apple-system,BlinkMacSystemFont,"Segoe UI","Hiragino Kaku Gothic ProN","Hiragino Sans","Yu Gothic UI","Yu Gothic",Meiryo,"Noto Sans JP",system-ui,sans-serif;--mono:ui-monospace,SFMono-Regular,"SF Mono",Menlo,Consolas,"Liberation Mono",monospace;--lh:1.6;--gap:16px;--pad:18px}*,:after,:before{box-sizing:border-box}html{-webkit-text-size-adjust:100%}body{font-family:var(--font);font-size:15px;line-height:var(--lh);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;text-rendering:optimizeLegibility;font-feature-settings:"palt" 1}body,h1,h2,h3,h4,p{margin:0}.ln{display:inline-block}a{color:var(--brand);text-decoration:none}a:hover{text-decoration:underline}:focus-visible{outline:2px solid var(--focus);outline-offset:2px;border-radius:4px}*{scrollbar-width:thin;scrollbar-color:var(--line-strong) transparent}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:var(--line-strong);border-radius:8px;border:2px solid var(--bg)}::-webkit-scrollbar-track{background:transparent}.app-shell{display:flex;flex-direction:column}.topnav{gap:6px;padding:0 18px;height:56px;background:var(--brand);box-shadow:0 1px 0 var(--brand-700),0 2px 10px rgba(20,33,53,.18);overflow-x:auto;scrollbar-width:none}.topnav::-webkit-scrollbar{display:none}.topnav .brand{font-weight:700;font-size:16px;letter-spacing:.02em;white-space:nowrap;margin-right:14px;padding-right:14px;border-right:1px solid hsla(0,0%,100%,.25);color:#fff}.topnav .brand small{display:block;font-size:11px;font-weight:500;opacity:.8;line-height:1.2}.topnav .spacer{flex:1 1 auto}.nav-item{-webkit-appearance:none;-moz-appearance:none;appearance:none;border:0;background:transparent;color:hsla(0,0%,100%,.82);font:inherit;font-size:14px;font-weight:600;white-space:nowrap;padding:8px 13px;border-radius:var(--radius-sm);cursor:pointer;line-height:1.4;transition:background-color .12s ease,color .12s ease}.nav-item:hover{background:hsla(0,0%,100%,.12);color:#fff}.nav-item.active{background:#fff;color:var(--brand)}.nav-item:focus-visible{outline-color:#fff;outline-offset:2px}.page{flex:1 1 auto;width:100%;max-width:1500px;padding:20px 22px 56px}.page-head{display:flex;align-items:flex-end;flex-wrap:wrap;gap:10px 16px;margin-bottom:18px;padding-bottom:14px;border-bottom:1px solid var(--line)}.page-head h1{font-size:21px;font-weight:700;letter-spacing:.01em;color:var(--text);line-height:1.4}.page-head .sub{color:var(--muted)}.page-head .actions{margin-left:auto;display:flex;align-items:center;gap:8px;flex-wrap:wrap}.grid{display:grid;grid-template-columns:repeat(12,1fr);grid-gap:var(--gap);gap:var(--gap)}.col{grid-column:span 12}.col-2{grid-column:span 2}.col-3{grid-column:span 3}.col-4{grid-column:span 4}.col-5{grid-column:span 5}.col-6{grid-column:span 6}.col-7{grid-column:span 7}.col-8{grid-column:span 8}.col-9{grid-column:span 9}.col-12{grid-column:span 12}.row{align-items:center;gap:var(--gap)}.row.tight{gap:8px}.row.between{justify-content:space-between}.row.end{justify-content:flex-end}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);box-shadow:var(--shadow);padding:var(--pad)}.card+.card{margin-top:var(--gap)}.card-head{margin:-2px 0 14px;padding-bottom:12px;border-bottom:1px solid var(--line)}.card-head h2,.card-head h3{font-weight:700;color:var(--text);line-height:1.4}.card-head .sub{color:var(--muted);font-size:12px}.card-head .actions{margin-left:auto;display:flex;gap:8px;align-items:center}.kpi{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--brand);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:15px 17px;display:flex;flex-direction:column;gap:4px;min-height:92px}.kpi .kpi-label{font-size:12.5px;font-weight:600;color:var(--muted);letter-spacing:.01em}.kpi-num{font-size:30px;font-weight:700;line-height:1.15;color:var(--text);font-feature-settings:"tnum";font-variant-numeric:tabular-nums;letter-spacing:-.01em}.kpi-num .unit{font-size:14px;font-weight:600;color:var(--muted);margin-left:3px}.kpi .kpi-foot{font-size:12px;color:var(--muted)}.kpi.is-ok{border-left-color:var(--ok)}.kpi.is-warn{border-left-color:var(--warn)}.kpi.is-danger{border-left-color:var(--danger)}.kpi.is-finished{border-left-color:var(--finished)}.btn{-webkit-appearance:none;-moz-appearance:none;appearance:none;display:inline-flex;align-items:center;justify-content:center;gap:7px;font:inherit;font-weight:600;line-height:1.2;white-space:nowrap;padding:9px 15px;min-height:38px;border:1px solid var(--line-strong);border-radius:var(--radius-sm);background:var(--surface);color:var(--text);transition:background-color .12s ease,border-color .12s ease,box-shadow .12s ease,color .12s ease}.btn:hover{background:var(--surface-2);border-color:var(--line-strong)}.btn:active{transform:translateY(.5px)}.btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.btn-primary{background:var(--brand);border-color:var(--brand);box-shadow:var(--shadow-sm)}.btn-primary:hover{background:var(--brand-700);border-color:var(--brand-700)}.btn-ghost{border-color:transparent;color:var(--brand)}.btn-ghost:hover{background:var(--brand-tint);border-color:transparent}.btn-danger{background:var(--danger);border-color:var(--danger)}.btn-danger:hover{background:#a31f15;border-color:#a31f15}.btn.sm{min-height:32px;padding:6px 11px;font-size:13px}.btn.lg{min-height:44px;padding:12px 20px;font-size:15px}.btn.block{width:100%}.field{gap:6px;min-width:0}.field .label,.field>label{font-size:12.5px;font-weight:600;color:var(--muted)}.field .hint{font-size:11.5px;color:var(--muted)}.field.inline{flex-direction:row;align-items:center;gap:10px}.input,.select,textarea.input{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;font:inherit;font-size:14px;line-height:1.4;color:var(--text);background:var(--surface);border:1px solid var(--line-strong);border-radius:var(--radius-sm);padding:9px 12px;min-height:38px;transition:border-color .12s ease,box-shadow .12s ease}.input::placeholder,textarea.input::placeholder{color:#98a1b0}.input:hover,.select:hover{border-color:var(--brand-300)}.input:focus,.select:focus,textarea.input:focus{outline:none;border-color:var(--focus);box-shadow:0 0 0 3px rgba(37,99,235,.18)}.input:disabled,.select:disabled{background:var(--surface-2);color:var(--muted);cursor:not-allowed}textarea.input{min-height:84px;resize:vertical}.select{padding-right:34px;background-image:linear-gradient(45deg,transparent 50%,var(--muted) 50%),linear-gradient(135deg,var(--muted) 50%,transparent 50%);background-position:calc(100% - 17px) calc(50% - 2px),calc(100% - 12px) calc(50% - 2px);background-size:5px 5px,5px 5px;background-repeat:no-repeat}.slider{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:100%;height:6px;border-radius:999px;background:var(--line);cursor:pointer;outline-offset:4px}.slider::-webkit-slider-runnable-track{height:6px;border-radius:999px;background:transparent}.slider::-moz-range-track{height:6px;border-radius:999px;background:var(--line)}.slider::-moz-range-progress{height:6px;border-radius:999px;background:var(--brand-300)}.slider::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:18px;height:18px;margin-top:-6px;border-radius:50%;background:var(--brand);border:2px solid #fff;box-shadow:var(--shadow-sm);cursor:pointer;-webkit-transition:transform .1s ease;transition:transform .1s ease}.slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:var(--brand);border:2px solid #fff;box-shadow:var(--shadow-sm);cursor:pointer}.slider:hover::-webkit-slider-thumb{transform:scale(1.08)}.slider:focus-visible::-webkit-slider-thumb{box-shadow:0 0 0 4px rgba(37,99,235,.25)}.slider:disabled{opacity:.5;cursor:not-allowed}.slider-row{display:grid;grid-template-columns:1fr auto;align-items:center;grid-gap:6px 12px;gap:6px 12px}.slider-row .slider-val{font-feature-settings:"tnum";font-variant-numeric:tabular-nums;font-weight:700;font-size:13px;color:var(--brand);min-width:3ch;text-align:right}.table{border-collapse:separate;border-spacing:0;font-size:13.5px}.table,.table-wrap{width:100%;background:var(--surface)}.table-wrap{border:1px solid var(--line);border-radius:var(--radius);max-height:70vh}.table thead th{position:relative;text-align:left;font-weight:700;color:var(--text);background:var(--surface-2);padding:11px 14px;white-space:nowrap;border-bottom:2px solid var(--line-strong);letter-spacing:.01em}.table.sticky thead th{position:-webkit-sticky;position:sticky;top:0;z-index:3;box-shadow:0 1px 0 var(--line-strong)}.table tbody td{padding:10px 14px;border-bottom:1px solid var(--line);color:var(--text);vertical-align:middle;line-height:1.5}.table tbody tr:last-child td{border-bottom:0}.table tbody tr:nth-child(2n) td{background:#fafbfd}.table tbody tr:hover td{background:var(--brand-tint)}.table tbody tr.is-selected td{background:#dbe6f4;box-shadow:inset 3px 0 0 var(--brand)}.table .num{text-align:right;font-feature-settings:"tnum";font-variant-numeric:tabular-nums;white-space:nowrap}.table .center{text-align:center}.table .nowrap{white-space:nowrap}.table .code{font-family:var(--mono);font-size:12.5px;color:var(--muted)}.badge{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;line-height:1.3;padding:3px 9px;border-radius:999px;border:1px solid transparent;white-space:nowrap;letter-spacing:.01em}.badge-ok{color:var(--ok);background:var(--ok-bg);border-color:#bfe3cd}.badge-warn{color:var(--warn);background:var(--warn-bg);border-color:#f0d6b4}.badge-danger{color:var(--danger);background:var(--danger-bg);border-color:#f1c4c0}.badge-muted{color:var(--muted);background:var(--neutral-bg);border-color:#d6dae0}.board{display:grid;grid-template-columns:repeat(auto-fill,minmax(232px,1fr));grid-gap:12px;gap:12px;align-items:stretch}.board-cell{background:var(--surface);border:1px solid var(--line);border-left:4px solid var(--line-strong);border-radius:var(--radius);box-shadow:var(--shadow-sm);padding:12px 13px;display:flex;flex-direction:column;gap:7px;min-height:96px;transition:box-shadow .12s ease,border-color .12s ease}.board-cell:hover{box-shadow:var(--shadow)}.board-cell .bc-head{display:flex;align-items:center;gap:8px}.board-cell .bc-title{font-weight:700;font-size:13.5px;color:var(--text);line-height:1.4;flex:1 1 auto;min-width:0}.board-cell .bc-sub{font-size:11.5px;color:var(--muted)}.board-cell .bc-time{font-family:var(--mono);font-size:12px;color:var(--muted);font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.board-cell .bc-person{display:flex;align-items:center;gap:7px;font-size:13px}.board-cell.s-on_duty{border-left-color:var(--ok)}.board-cell.s-late{border-left-color:var(--danger)}.board-cell.s-not_arrived{border-left-color:var(--neutral)}.board-cell.s-on_break{border-left-color:var(--warn)}.board-cell.s-finished{border-left-color:var(--finished)}.board-cell.s-absent{border-left-color:var(--absent)}.board-cell.is-unfilled{border-style:dashed dashed dashed solid;border-left-color:var(--danger);background:var(--danger-bg)}.status-dot{display:inline-block;width:11px;height:11px;flex:0 0 auto;border-radius:50%;border:1.5px solid rgba(0,0,0,.08);box-shadow:0 0 0 2px hsla(0,0%,100%,.9);vertical-align:middle}.status-dot,.status-dot.not_arrived{background:var(--neutral)}.status-dot.late{background:var(--danger)}.status-dot.on_duty{background:var(--ok)}.status-dot.on_break{background:var(--warn)}.status-dot.finished{background:var(--finished)}.status-dot.absent{background:var(--absent)}.status-dot.on_duty{box-shadow:0 0 0 2px hsla(0,0%,100%,.9),0 0 0 4px rgba(30,125,70,.25)}.legend{display:flex;flex-wrap:wrap;align-items:center;gap:6px 16px;font-size:12.5px;color:var(--muted)}.legend .legend-item,.pill{display:inline-flex;align-items:center;gap:6px;white-space:nowrap}.pill{font-size:12.5px;font-weight:600;line-height:1.3;padding:5px 12px;border-radius:999px;border:1px solid var(--line-strong);background:var(--surface);color:var(--text);cursor:pointer;transition:background-color .12s ease,border-color .12s ease,color .12s ease}.pill:hover{background:var(--surface-2);border-color:var(--brand-300)}.pill.active{background:var(--brand);border-color:var(--brand);color:#fff}.pill.active:hover{background:var(--brand-700)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:8px;text-align:center;color:var(--muted);padding:40px 20px;border:1px dashed var(--line-strong);border-radius:var(--radius);background:var(--surface-2)}.empty .empty-title{font-size:14px;font-weight:700;color:var(--text)}.empty .empty-sub{font-size:13px}.muted{color:var(--muted)}.num{font-feature-settings:"tnum";font-variant-numeric:tabular-nums}.mono{font-family:var(--mono)}.right{margin-left:auto}.divider{height:1px;background:var(--line);border:0;margin:16px 0}.hidden{display:none!important}@media (max-width:1024px){.page{padding:18px 16px 48px}.col-2,.col-3,.col-4{grid-column:span 6}.col-5,.col-7,.col-8,.col-9{grid-column:span 12}.board{grid-template-columns:repeat(auto-fill,minmax(210px,1fr))}}@media (max-width:640px){body{font-size:14.5px}.topnav{height:52px;padding:0 12px}.topnav .brand{font-size:15px;margin-right:10px;padding-right:10px}.nav-item{padding:8px 11px}.page{padding:14px 12px 44px}.page-head{align-items:flex-start}.page-head h1{font-size:18px}.page-head .actions{width:100%;margin-left:0}.grid{grid-template-columns:1fr;gap:12px}.col,[class*=col-]{grid-column:1/-1}.card{padding:14px;border-radius:var(--radius-sm)}.kpi-num{font-size:26px}.board{grid-template-columns:1fr}.table-wrap{max-height:62vh}.table{font-size:13px}.table tbody td,.table thead th{padding:9px 11px}.btn{min-height:44px}.btn,.input,.select{font-size:15px}.row.actions-stack{flex-direction:column;align-items:stretch}.row.actions-stack .btn{width:100%}}@media (max-width:360px){.page{padding:12px 10px 40px}.card{padding:12px}.kpi-num{font-size:24px}}@media (prefers-reduced-motion:reduce){*{animation:none!important;transition:none!important}}@media print{body{background:#fff}.btn,.page-head .actions,.pill,.slider,.topnav{display:none!important}.board-cell,.card,.kpi{box-shadow:none;border-color:#999}.table.sticky thead th{position:static}}.dt-toolbar{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-bottom:10px}.dt-search{position:relative;flex:1 1 220px;min-width:160px}.dt-search-ic{position:absolute;left:9px;top:50%;transform:translateY(-50%);opacity:.5;font-size:13px;pointer-events:none}.dt-search .input{width:100%;padding-left:30px}.dt-filter{min-width:120px}.dt-extra{display:flex;gap:8px;align-items:center}.dt-clear,.dt-count{white-space:nowrap}.dt-count{margin-left:auto;color:var(--muted,#5b6573);font-size:12px}.table-wrap{overflow:auto;border:1px solid var(--line,#d3d9e2);border-radius:var(--radius,10px);background:var(--surface,#fff)}.table-wrap .table{margin:0}.table th.is-sortable{cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;white-space:nowrap}.table th.is-sortable:hover{background:#e9eef5}.ta-right{text-align:right}.ta-center{text-align:center}.table tr.is-clickable{cursor:pointer}.table tr.is-clickable:hover td{background:#eef4fb}.dt-empty{text-align:center;padding:28px 12px}.chip,.dt-empty{color:var(--muted,#5b6573)}.chip{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;background:#eef1f5;border:1px solid var(--line,#d3d9e2)}.chip-brand{background:#e8eef6;color:var(--brand,#1f3a5f);border-color:#c9d8ea}.chip-ok{background:#e3f3ea;color:var(--ok,#1e7d46);border-color:#bfe3cd}.chip-warn{background:#fdeede;color:var(--warn,#b15c00);border-color:#f3d4ab}.chip-danger{background:#fae3e1;color:var(--danger,#c2261b);border-color:#f0c2bd}.status-label{font-size:12px;color:var(--text,#1f2937);vertical-align:middle}body.ui-locked{overflow:hidden}#ui-layer-host{position:fixed;inset:0;z-index:1000;pointer-events:none}.ui-overlay{position:fixed;inset:0;pointer-events:auto;display:flex}.ui-scrim{position:absolute;inset:0;background:rgba(17,26,42,.46)}.ui-overlay-modal{align-items:center;justify-content:center;padding:24px}.ui-overlay-drawer{justify-content:flex-end}.ui-drawer,.ui-modal{position:relative;background:var(--surface,#fff);border-radius:var(--radius,10px);box-shadow:0 18px 50px rgba(0,0,0,.3);display:flex;flex-direction:column;max-height:calc(100vh - 48px);animation:ui-pop .14s ease-out}.ui-modal{width:min(720px,100%)}.ui-modal.lg{width:min(960px,100%)}.ui-modal.sm{width:min(480px,100%)}.ui-drawer{width:min(560px,100%);height:100vh;max-height:100vh;border-radius:0}.ui-drawer.left{animation:ui-slide-l .16s ease-out}.ui-drawer{animation:ui-slide-r .16s ease-out}@keyframes ui-pop{0%{transform:translateY(8px) scale(.98);opacity:0}}@keyframes ui-slide-r{0%{transform:translateX(40px);opacity:.4}}@keyframes ui-slide-l{0%{transform:translateX(-40px);opacity:.4}}.ui-panel-head{display:flex;align-items:center;gap:12px;padding:14px 18px;border-bottom:1px solid var(--line,#d3d9e2)}.ui-panel-title{font-weight:700;font-size:16px;color:var(--text,#1f2937);flex:1 1}.ui-panel-sub{padding:8px 18px 0;color:var(--muted,#5b6573);font-size:13px}.ui-panel-body{padding:16px 18px;overflow:auto}.ui-panel-foot{padding:12px 18px;border-top:1px solid var(--line,#d3d9e2);display:flex;gap:8px;justify-content:flex-end}.ui-x{background:transparent;border:0;font-size:22px;line-height:1;color:var(--muted,#5b6573);cursor:pointer;padding:2px 6px;border-radius:6px}.ui-x:hover{background:#eef1f5;color:var(--text,#1f2937)}.cal{border:1px solid var(--line,#d3d9e2);border-radius:var(--radius,10px);overflow:hidden;background:var(--surface,#fff)}.cal-grid{display:grid;grid-template-columns:repeat(7,minmax(0,1fr))}.cal-head .cal-h{text-align:center;font-size:12px;font-weight:700;color:var(--muted,#5b6573);padding:8px 0;background:#f3f6fa;border-bottom:1px solid var(--line,#d3d9e2)}.cal-head .cal-h.cal-sat{color:#2563a8}.cal-head .cal-h.cal-sun{color:#c2261b}.cal-cell{min-width:0;overflow:hidden;min-height:84px;border-right:1px solid var(--line,#eef1f5);border-bottom:1px solid var(--line,#eef1f5);padding:6px 7px 7px;position:relative;transition:background-color .12s ease,box-shadow .15s ease}.cal-cell.is-clickable{cursor:pointer}.cal-cell.is-clickable:hover{background:#eef4fb;box-shadow:inset 0 0 0 2px #cfe0f5;z-index:1}.cal-empty{background:#fafbfc}.cal-d{display:inline-flex;align-items:center;justify-content:center;min-width:20px;height:20px;padding:0 4px;font-size:12.5px;font-weight:700;color:var(--text,#1f2937);border-radius:6px}.cal-cell.cal-sat .cal-d{color:#2563a8}.cal-cell.cal-sun .cal-d{color:#c2261b}.cal-cell.is-today .cal-d{background:var(--brand,#1f3a5f);color:#fff}.cal-cell.is-today{box-shadow:inset 0 0 0 2px var(--brand,#1f3a5f)}.cal-cell.heat-ok{background:#eef7f1;box-shadow:inset 3px 0 0 #2f9e63}.cal-cell.heat-warn{background:#fdf3e6;box-shadow:inset 3px 0 0 #d98324}.cal-cell.heat-danger{background:#fceae8;box-shadow:inset 3px 0 0 #d0392b}.cal-cell.is-today.heat-danger,.cal-cell.is-today.heat-ok,.cal-cell.is-today.heat-warn{box-shadow:inset 0 0 0 2px var(--brand,#1f3a5f)}.cal-rate{font-size:11px;color:var(--muted,#5b6573);margin-top:2px}.cal-rate.strong{color:var(--text,#1f2937);font-weight:700;font-size:12px}.cal-gc{border-color:#dadce0}.cal-gc .cal-head .cal-h{background:#fff;color:#70757a;font-weight:500;border-bottom:1px solid #dadce0}.cal-gc .cal-head .cal-h.cal-sat{color:#1a73e8}.cal-gc .cal-head .cal-h.cal-sun{color:#d93025}.cal-gc .cal-cell{min-height:102px;background:#fff!important;box-shadow:none!important;border-color:#e8eaed;padding:4px 5px 6px}.cal-gc .cal-cell.is-clickable:hover{background:#f8fafd!important;box-shadow:none!important}.cal-gc .cal-d{font-size:12px;font-weight:600;color:#3c4043;min-width:24px;height:24px;margin:0 auto 2px 0}.cal-gc .cal-cell.cal-sun .cal-d{color:#d93025}.cal-gc .cal-cell.cal-sat .cal-d{color:#1a73e8}.cal-gc .cal-cell.is-today .cal-d{background:#1a73e8;color:#fff;border-radius:50%}.gc-ev{display:block;font-size:11px;line-height:1.55;padding:1px 6px;border-radius:4px;margin-top:3px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-weight:600}.gc-ev.neutral{background:#e8f0fe;color:#1967d2}.gc-ev.ok{background:#e6f4ea;color:#137333}.gc-ev.warn{background:#fef7e0;color:#9c6200}.gc-ev.danger{background:#fce8e6;color:#c5221f}@media (max-width:640px){.cal-gc .cal-cell{min-height:64px;padding:3px}.cal-gc .cal-d{min-width:18px;height:18px;font-size:11px}.gc-ev{font-size:9px;padding:0 3px;line-height:1.4;margin-top:2px}}.cal-pick .cal-cell{min-height:48px;cursor:pointer;padding:5px 4px}.cal-pick .cal-cell .cal-d{font-size:13px}.cal-pick .cal-cell.is-clickable:hover{background:#eef4fb;box-shadow:inset 0 0 0 2px #cfe0f5}.cal-pick .cal-cell.md-on{background:var(--brand,#1f3a5f);box-shadow:none}.cal-pick .cal-cell.md-on .cal-d{color:#fff;background:transparent}.cal-pick .cal-cell.md-on.is-today{box-shadow:inset 0 0 0 2px #fff}.cal-pick .cal-cell.md-on:after{content:"✓";position:absolute;right:5px;bottom:3px;color:#fff;font-size:12px;font-weight:700}.cal-bar{height:6px;border-radius:4px;background:#e6eaef;overflow:hidden;margin-top:4px}.cal-bar>span{display:block;height:100%;border-radius:4px}.cal-bar>span.bar-ok{background:#2f9e63}.cal-bar>span.bar-warn{background:#d98324}.cal-bar>span.bar-danger{background:#d0392b}.cal-legend{display:flex;flex-wrap:wrap;gap:12px;align-items:center;margin:0 0 10px;font-size:12px;color:var(--text,#1f2937)}.cal-legend .lg{display:inline-flex;align-items:center;gap:5px}.cal-legend .lg-swatch{width:12px;height:12px;border-radius:3px;display:inline-block}.cal-legend .sw-ok{background:#2f9e63}.cal-legend .sw-warn{background:#d98324}.cal-legend .sw-danger{background:#d0392b}.kv{display:grid;grid-template-columns:max-content 1fr;grid-gap:6px 14px;gap:6px 14px;font-size:13px}.kv dt{color:var(--muted,#5b6573)}.kv dd{margin:0;color:var(--text,#1f2937)}.mini-list{display:flex;flex-direction:column;gap:6px}.mini-row{display:flex;align-items:center;gap:10px;padding:8px 10px;border:1px solid var(--line,#d3d9e2);border-radius:8px;background:#fff}.mini-row.is-clickable{cursor:pointer}.mini-row.is-clickable:hover{background:#eef4fb}.mini-grow{flex:1 1;min-width:0}.unit{font-weight:600;margin-left:2px}.section-label,.unit{font-size:12px;color:var(--muted,#5b6573)}.section-label{font-weight:700;margin:14px 0 6px;text-transform:none}@media (max-width:640px){.dt-count{margin-left:0;order:5;flex-basis:100%}.ui-overlay-modal{padding:0;align-items:stretch}.ui-modal{width:100%;max-height:100vh;border-radius:0}.cal-cell{min-height:60px;padding:4px 4px 5px}.cal-d{min-width:18px;height:18px;font-size:11.5px}.cal-head .cal-h{font-size:11px;padding:6px 0}.cal-rate{font-size:9.5px;margin-top:1px}.cal-rate.strong{font-size:10.5px}.cal-bar{height:4px;margin-top:2px}}.ui-overlay-loading{align-items:center;justify-content:center;pointer-events:auto}.ui-overlay-loading .ui-scrim{background:rgba(17,26,42,.32)}.ui-loader{position:relative;background:hsla(0,0%,100%,.97);border-radius:16px;padding:26px 34px;display:flex;flex-direction:column;align-items:center;gap:14px;box-shadow:0 16px 48px rgba(0,0,0,.28);animation:ui-pop .22s cubic-bezier(.32,.72,0,1)}.ui-spinner{width:40px;height:40px;border-radius:50%;border:3px solid rgba(31,58,95,.16);border-top:3px solid var(--brand,#1f3a5f);animation:ui-spin .7s linear infinite}.ui-loader-text{font-size:14px;font-weight:700;color:var(--text,#1f2937)}.ui-loader-sub{font-size:12px;color:var(--muted,#5b6573);margin-top:-6px;text-align:center;max-width:240px}@keyframes ui-spin{to{transform:rotate(1turn)}}.ui-modal{animation:ui-pop .24s cubic-bezier(.32,.72,0,1)}.ui-drawer{animation:ui-slide-r .26s cubic-bezier(.32,.72,0,1)}.ui-drawer.left{animation:ui-slide-l .26s cubic-bezier(.32,.72,0,1)}.ui-scrim{animation:ui-fade .2s ease-out}@keyframes ui-fade{0%{opacity:0}}@media (prefers-reduced-motion:reduce){*,:after,:before{animation-duration:.001ms!important;animation-iteration-count:1!important;transition-duration:.001ms!important}.ui-spinner{animation:ui-spin .8s linear infinite!important}}#ui-toast-host{position:fixed;top:14px;left:0;right:0;z-index:1200;flex-direction:column;gap:8px;pointer-events:none}#ui-toast-host,.ui-toast{display:flex;align-items:center}.ui-toast{pointer-events:auto;gap:12px;background:#1f2937;color:#fff;border-radius:10px;padding:11px 16px;font-size:14px;box-shadow:0 8px 28px rgba(0,0,0,.3);max-width:calc(100% - 32px);animation:ui-toast-in .22s cubic-bezier(.32,.72,0,1)}.ui-toast.is-danger{background:#7a1f17}.ui-toast.is-ok{background:#155e35}.ui-toast.leaving{opacity:0;transform:translateY(-8px);transition:opacity .18s,transform .18s}.ui-toast-act{background:transparent;border:1px solid hsla(0,0%,100%,.45);color:#fff;border-radius:8px;padding:6px 12px;font-size:13px;font-weight:700;cursor:pointer;min-height:36px;white-space:nowrap}.ui-toast-act:hover{background:hsla(0,0%,100%,.14)}@keyframes ui-toast-in{0%{opacity:0;transform:translateY(-12px)}}.ui-x{min-width:44px;min-height:44px;display:grid;place-items:center}.btn.sm{min-height:40px}.chip-warn{color:#8a4700}.chip-danger{color:#9e1c14}.chip-ok{color:#155e35}.table.dense{font-size:12.5px}.table.dense thead th{padding:7px 10px}.table.dense tbody td{padding:4px 10px;line-height:1.35}.table.dense tbody td .muted{font-size:10.5px!important;line-height:1.2}.dp .dp-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.dp .dp-title{font-weight:800}.dp .dp-foot{margin-top:12px}.dp .dp-foot .btn{width:100%;box-sizing:border-box}.cal-cell.dp-sel{outline:2px solid var(--brand-600,#2c5f5d);outline-offset:-2px;border-radius:8px}.cal-cell.dp-has{background:#eef6f4}.dp-dot{display:inline-block;width:6px;height:6px;border-radius:50%;background:var(--ok,#1e7d46);margin-top:2px}.dt-detail-hint,.mobile-only{display:none}@media (max-width:640px){.dt-hide-mobile{display:none!important}.mobile-only{display:block}.table tr.is-clickable td:first-child{position:relative;padding-right:18px}.table tr.is-clickable td:first-child:after{content:"›";position:absolute;right:6px;top:50%;transform:translateY(-50%);color:var(--muted,#9aa3af);font-weight:700;font-size:15px}.dt-detail-hint{display:block;font-size:11.5px;color:var(--muted,#5b6573);margin:0 0 8px}}.copy-bar{display:flex;align-items:center;flex-wrap:wrap;gap:8px;margin-bottom:12px;padding:8px 10px;background:#f1f6fb;border:1px solid #d8e3f0;border-radius:9px}.md{border:1px solid var(--line,#d3d9e2);border-radius:12px;padding:14px;background:#fbfcfe}.md-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px}.md-title{font-weight:800;font-size:15px;color:var(--text,#1f2937)}.md-tools{display:flex;flex-direction:column;gap:10px;margin-top:12px;padding-top:12px;border-top:1px solid var(--line,#eef1f5)}.md-tool{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.md-tlabel{font-size:12px;font-weight:700;min-width:116px}.md-sep,.md-tlabel{color:var(--muted,#5b6573)}.md-date{max-width:170px}.md-dows{display:inline-flex;gap:5px;flex-wrap:wrap}.md-dow{min-width:36px;min-height:36px;border:1px solid var(--line,#d3d9e2);background:#fff;border-radius:8px;cursor:pointer;font-weight:700;font-size:13px;color:var(--text,#1f2937)}.md-dow.on{background:var(--brand,#1f3a5f);color:#fff;border-color:var(--brand,#1f3a5f)}.md-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:12px}.md-count{font-size:12.5px;font-weight:800;color:var(--brand,#1f3a5f);margin-right:2px}.md-chip{color:var(--text,#1f2937)}@media (max-width:640px){.md{padding:10px}.md-tlabel{min-width:100%}.md-date{max-width:44%}}.ui-scrolltop{position:fixed;right:18px;bottom:20px;z-index:120;display:inline-flex;align-items:center;gap:6px;padding:10px 14px;min-height:44px;background:var(--brand,#1f3a5f);color:#fff;border:0;border-radius:999px;cursor:pointer;font-size:13px;font-weight:700;box-shadow:0 4px 14px rgba(0,0,0,.25);opacity:0;transform:translateY(12px);pointer-events:none;transition:opacity .2s ease,transform .2s ease}.ui-scrolltop.show{opacity:1;transform:none;pointer-events:auto}.ui-scrolltop:hover{background:#16294a}.ui-scrolltop .ui-st-l{font-size:12px}.ui-scrolltop.above-tab{bottom:84px}@media (max-width:640px){.ui-scrolltop{right:14px;bottom:16px;padding:10px 12px}.ui-scrolltop.above-tab{bottom:80px}.ui-scrolltop .ui-st-l{display:none}}@media (prefers-reduced-motion:reduce){.ui-scrolltop{transition:opacity .2s ease;transform:none}}.app-shell{min-height:100vh;background:var(--bg,#eef1f5)}.topnav{display:flex;align-items:center;gap:14px;flex-wrap:wrap;padding:10px 18px;background:var(--brand,#1f3a5f);color:#fff;position:-webkit-sticky;position:sticky;top:0;z-index:50;box-shadow:0 1px 6px rgba(0,0,0,.18)}.topnav.is-staff{background:#2a6048}.brand{display:flex;align-items:center;gap:8px;font-weight:700}.brand-mark{display:inline-grid;place-items:center;width:28px;height:28px;background:#fff;color:var(--brand,#1f3a5f);border-radius:7px;font-weight:800}.topnav.is-staff .brand-mark{color:#2a6048}.brand-name{font-size:15px}.brand-badge{font-size:10px;font-weight:700;background:hsla(0,0%,100%,.2);color:#fff;padding:2px 7px;border-radius:999px}.brand-switch{font-size:11px;color:#dfe7f1;text-decoration:none;margin-left:4px;border:1px solid hsla(0,0%,100%,.3);padding:2px 8px;border-radius:999px}.brand-switch:hover{background:hsla(0,0%,100%,.14)}.nav-items{display:flex;gap:4px;flex-wrap:wrap;flex:1 1}.topnav .nav-item{background:transparent;color:#dfe7f1;border:0;cursor:pointer;padding:8px 12px;border-radius:8px;font-size:13px;font-weight:600;min-height:40px;white-space:nowrap}.topnav .nav-item:hover{background:hsla(0,0%,100%,.12);color:#fff}.topnav .nav-item.active{background:#fff;color:var(--brand,#1f3a5f)}.topnav.is-staff .nav-item.active{color:#2a6048}.nav-now{font-size:12px;color:#cdd8e6;white-space:nowrap}.nav-user{display:flex;align-items:center;gap:6px}.nav-user-ic{width:26px;height:26px;border-radius:50%;background:#fff;color:#2a6048;display:grid;place-items:center;font-weight:800;font-size:13px}.nav-user-sel{background:hsla(0,0%,100%,.14);color:#fff;border:1px solid hsla(0,0%,100%,.3);border-radius:8px;padding:6px 8px;font-size:12px;max-width:180px}.nav-user-sel option{color:#1f2937}.page{padding:20px;max-width:1280px;margin:0 auto}.page-head{margin-bottom:14px}.page-head h1{font-size:20px;margin:0 0 4px;color:var(--text,#1f2937)}.page-head .sub{margin:0;color:var(--muted,#5b6573);font-size:13px;line-height:1.6}.grid.kpis4{grid-template-columns:repeat(4,1fr);grid-gap:12px}.grid.kpis2,.grid.kpis4{display:grid;gap:12px;margin-bottom:16px}.grid.kpis2{grid-template-columns:repeat(2,1fr);grid-gap:12px}.kpi{background:var(--surface,#fff);border:1px solid var(--line,#d3d9e2);border-left:4px solid var(--neutral,#5b6573);border-radius:var(--radius,10px);padding:12px 14px}.kpi.is-ok{border-left-color:var(--ok,#1e7d46)}.kpi.is-warn{border-left-color:var(--warn,#b15c00)}.kpi.is-danger{border-left-color:var(--danger,#c2261b)}.kpi.is-muted{border-left-color:var(--neutral,#5b6573)}.kpi-label{font-size:12px;color:var(--muted,#5b6573)}.kpi-num{font-size:24px;font-weight:800;color:var(--text,#1f2937);line-height:1.2;margin:2px 0}.kpi-sub{font-size:11px;color:var(--muted,#5b6573)}.card{background:var(--surface,#fff);border:1px solid var(--line,#d3d9e2);border-radius:var(--radius,10px);padding:16px;margin-bottom:16px}.card-head{display:flex;align-items:center;justify-content:space-between;gap:10px;font-weight:700;color:var(--text,#1f2937);margin-bottom:10px}.card-head h2,.card-head h3{margin:0;font-size:15px}.muted{color:var(--muted,#5b6573)}.row{display:flex;gap:10px;flex-wrap:wrap}.row.tight{gap:6px}.actions{display:flex;gap:8px;flex-wrap:wrap}.help,.note{color:var(--muted,#5b6573);font-size:13px;line-height:1.7}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);grid-gap:12px;gap:12px}.field{gap:4px}.field label{font-weight:600}.board-sites{display:grid;grid-template-columns:repeat(auto-fill,minmax(330px,1fr));grid-gap:12px;gap:12px}.site-card{margin:0}.site-card.has-short{border-color:#f0c2bd}.site-card-head{display:flex;align-items:flex-start;justify-content:space-between;gap:10px;margin-bottom:8px;padding-bottom:8px;border-bottom:1px solid var(--line,#eef1f5)}.site-name{font-weight:700;color:var(--text,#1f2937);display:block}.site-client{font-size:12px;color:var(--muted,#5b6573)}.post-row{padding:6px 0;border-top:1px dashed #eef1f5}.post-row:first-of-type{border-top:0}.post-meta{display:flex;align-items:center;gap:6px;flex-wrap:wrap;margin-bottom:4px}.post-name{font-weight:600;font-size:13px;color:var(--text,#1f2937)}.post-time{font-size:12px;color:var(--muted,#5b6573)}.post-slots{display:flex;flex-wrap:wrap;gap:6px}.slot-chip{display:inline-flex;align-items:center;gap:5px;font-size:12px;background:#f4f7fb;border:1px solid var(--line,#d3d9e2);border-radius:999px;padding:3px 9px}.slot-t{color:var(--muted,#5b6573);font-size:11px}.wk-table td.wk-site,.wk-table th.wk-site{text-align:left;min-width:150px;position:-webkit-sticky;position:sticky;left:0;background:var(--surface,#fff);z-index:1}.wk-client{display:block;font-size:11px;color:var(--muted,#5b6573);font-weight:400}.wk-day{cursor:pointer;white-space:nowrap}.wk-day:hover{background:#e9eef5}.wk-cell{text-align:center;font-size:12px;font-weight:600}.wk-cell.heat-ok{background:#e7f4ec;color:var(--ok,#1e7d46)}.wk-cell.heat-warn{background:#fdf0e0;color:var(--warn,#b15c00)}.wk-cell.heat-danger{background:#fae4e2;color:var(--danger,#c2261b)}.wk-cell.wk-none,.wk-none{color:#c2c8d2;text-align:center}.mini-row.is-short{background:#fdf3f2;border-color:#f0c2bd}.launch{min-height:100vh;display:grid;place-items:center;background:linear-gradient(160deg,#1f3a5f,#2a6048);padding:24px}.launch-box{background:#fff;border-radius:16px;padding:32px;max-width:720px;width:100%;box-shadow:0 20px 60px rgba(0,0,0,.3)}.launch-box h1{margin:0 0 4px;font-size:22px}.launch-box .sub{color:var(--muted,#5b6573);margin:0 0 22px}.launch-cards{display:grid;grid-template-columns:1fr 1fr;grid-gap:16px;gap:16px}.launch-card{display:block;text-decoration:none;color:inherit;border:2px solid var(--line,#d3d9e2);border-radius:12px;padding:22px;transition:.12s}.launch-card:hover{border-color:var(--brand,#1f3a5f);box-shadow:0 8px 24px rgba(31,58,95,.16);transform:translateY(-2px)}.launch-card.staff:hover{border-color:#2a6048}.launch-ic{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;font-size:22px;font-weight:800;color:#fff;background:var(--brand,#1f3a5f);margin-bottom:12px}.launch-card.staff .launch-ic{background:#2a6048}.launch-card h2{margin:0 0 6px;font-size:17px}.launch-card p{margin:0;color:var(--muted,#5b6573);font-size:13px;line-height:1.6}.sched-week{display:flex;flex-direction:column;gap:8px}.sched-day{display:grid;grid-template-columns:132px 1fr;grid-gap:12px;gap:12px;align-items:start;border:1px solid var(--line,#d3d9e2);border-radius:var(--radius,10px);padding:10px 12px}.sched-day.is-off{background:#f7f9fc}.sched-day.is-today{border-color:var(--brand,#1f3a5f);box-shadow:inset 3px 0 0 var(--brand,#1f3a5f)}.sched-date{display:flex;flex-direction:column;gap:4px;align-items:flex-start;padding-top:2px}.sched-dnum{font-weight:700;color:var(--text,#1f2937);font-size:14px;white-space:nowrap}.sched-jobs{display:flex;flex-direction:column;gap:6px;min-width:0}.sched-none{font-size:13px;padding:4px 2px}.sched-job{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:#f6f8fb;border:1px solid var(--line,#d3d9e2);border-radius:9px;padding:8px 10px;cursor:pointer;font:inherit;transition:.12s}.sched-job:hover{border-color:var(--brand,#1f3a5f);background:#eef3f9}.sched-job-main{display:flex;flex-direction:column;gap:1px;min-width:0;flex:1 1}.sched-site{font-weight:600;color:var(--text,#1f2937);font-size:13.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.sched-time{font-size:12px;color:var(--muted,#5b6573)}.sched-st{color:var(--text,#1f2937);font-weight:600}.sched-go{font-weight:700;font-size:16px}.cal-mini,.sched-go{color:var(--muted,#5b6573)}.cal-mini{font-size:10px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width:1024px){.grid.kpis4{grid-template-columns:repeat(2,1fr)}}@media (max-width:640px){.grid.kpis2,.grid.kpis4{grid-template-columns:1fr 1fr}.form-grid,.launch-cards{grid-template-columns:1fr}.nav-now{display:none}.nav-items{order:3;flex-basis:100%}.sched-day{grid-template-columns:1fr;gap:6px}}.auth-wrap{min-height:100vh;display:grid;place-items:center;padding:24px;background:linear-gradient(160deg,#1f3a5f,#26344d)}.auth-card{background:#fff;border-radius:16px;padding:28px;width:100%;max-width:420px;box-shadow:0 20px 60px rgba(0,0,0,.32)}.auth-brand{display:flex;align-items:center;gap:12px;margin-bottom:20px}.auth-mark{width:46px;height:46px;border-radius:12px;display:grid;place-items:center;color:#fff;font-weight:800;font-size:22px}.auth-title{font-weight:800;font-size:17px;color:var(--text,#1f2937)}.auth-sub{font-size:12px;color:var(--muted,#5b6573)}.auth-card .field{margin-bottom:14px}.auth-card .input,.auth-card .select{width:100%;box-sizing:border-box;padding:11px 12px;border:1px solid var(--line,#d3d9e2);border-radius:10px;font-size:15px}.auth-go{width:100%;margin-top:6px;padding:13px;font-size:15px}.auth-hint{font-size:11px;color:var(--muted,#5b6573);margin:12px 0 0}.auth-err{color:var(--danger,#c2261b);font-size:13px;min-height:18px;margin:8px 0 0}.hub{padding:20px;max-width:1100px;margin:0 auto}.hub-head{margin-bottom:16px}.hub-head h1{font-size:20px;margin:0 0 2px;color:var(--text,#1f2937)}.hub-head .sub{margin:0;color:var(--muted,#5b6573);font-size:13px}.hub-grid{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:14px;gap:14px}.hub-tile{text-align:left;cursor:pointer;background:#fff;border:1px solid var(--line,#d3d9e2);border-left:6px solid var(--c,#1f3a5f);border-radius:12px;padding:16px 18px;display:flex;flex-direction:column;gap:5px;min-height:104px;transition:.12s}.hub-tile:hover{box-shadow:0 8px 20px rgba(0,0,0,.13);transform:translateY(-2px);border-color:var(--c,#1f3a5f)}.hub-ic{font-size:26px;line-height:1}.hub-t{font-weight:800;font-size:16px;color:var(--text,#1f2937)}.hub-d{font-size:12px;color:var(--muted,#5b6573)}@media (max-width:760px){.hub-grid{grid-template-columns:1fr 1fr}}@media (max-width:460px){.hub-grid{grid-template-columns:1fr}}.app-shell.has-sidebar{display:flex;flex-direction:row;min-height:100vh;align-items:stretch}.sidebar{width:224px;flex:0 0 224px;background:var(--brand,#1f3a5f);color:#fff;display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100vh}.sb-brand{display:flex;align-items:center;gap:9px;padding:12px 14px 10px;border-bottom:1px solid hsla(0,0%,100%,.12);flex:0 0 auto}.sb-mark{width:30px;height:30px;border-radius:8px;background:#fff;color:var(--brand,#1f3a5f);display:grid;place-items:center;font-weight:800;font-size:15px;flex:0 0 auto}.sb-name{font-weight:700;font-size:13.5px;line-height:1.25}.sb-role{font-size:11px;color:#9fb0c6}.sb-nav{flex:1 1 auto;overflow-y:auto;padding:8px;display:flex;flex-direction:column;gap:1px}.sb-section{font-size:10.5px;font-weight:700;letter-spacing:.08em;color:#8aa0bd;text-transform:none;padding:7px 12px 2px;margin-top:1px}.sb-section:first-child{margin-top:0}.sb-item{display:flex;align-items:center;gap:9px;width:100%;text-align:left;background:transparent;color:#cdd8e6;border:0;cursor:pointer;padding:7px 12px;border-radius:8px;font-size:13.5px;font-weight:600;line-height:1.2}.sb-ic{width:18px;text-align:center;font-size:14px;flex:0 0 auto}.sb-label{flex:1 1 auto}.sb-item:hover{background:hsla(0,0%,100%,.1);color:#fff}.sb-item.active{background:#fff;color:var(--brand,#1f3a5f)}.sb-item.active .sb-ic{filter:none}.sb-foot{padding:9px 14px;border-top:1px solid hsla(0,0%,100%,.12);font-size:11px;color:#9fb0c6;flex:0 0 auto}.sb-now{white-space:nowrap}.sb-user{margin:1px 0 6px;color:#dfe7f1;font-size:12px}.sb-logout{background:transparent;border:1px solid hsla(0,0%,100%,.3);color:#cdd8e6;border-radius:8px;padding:5px 12px;font-size:12px;cursor:pointer}.sb-logout:hover{background:hsla(0,0%,100%,.12);color:#fff}.main-col{flex:1 1;min-width:0;display:flex;flex-direction:column}.mobilebar,.sb-scrim{display:none}@media (max-width:768px){.sidebar{position:fixed;left:0;top:0;height:100vh;transform:translateX(-100%);transition:transform .2s ease;z-index:200;box-shadow:2px 0 16px rgba(0,0,0,.3)}.sidebar.open{transform:none}.sb-scrim.show{display:block;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:150}.mobilebar{display:flex;align-items:center;gap:12px;background:var(--brand,#1f3a5f);color:#fff;padding:11px 14px;position:-webkit-sticky;position:sticky;top:0;z-index:100}.hamburger{background:transparent;border:0;color:#fff;font-size:22px;line-height:1;cursor:pointer;padding:2px 6px}.mb-title{font-weight:700;font-size:15px}}.page{animation:page-in .26s cubic-bezier(.32,.72,0,1)}.hub-tile{animation:page-in .3s cubic-bezier(.32,.72,0,1) backwards}.hub-tile:nth-child(2){animation-delay:.03s}.hub-tile:nth-child(3){animation-delay:.06s}.hub-tile:nth-child(4){animation-delay:.05s}.hub-tile:nth-child(5){animation-delay:.08s}.hub-tile:nth-child(6){animation-delay:.11s}.hub-tile:nth-child(7){animation-delay:.1s}.hub-tile:nth-child(8){animation-delay:.13s}.hub-tile:nth-child(9){animation-delay:.16s}.hub-tile:nth-child(10){animation-delay:.18s}.btn,.dt-clear,.flow-card,.hub-tile,.nav-item,.pill,.sb-item,.sb-logout,.table tbody tr,.ui-x{transition:background-color .15s ease,color .15s ease,transform .12s cubic-bezier(.32,.72,0,1),box-shadow .18s ease,border-color .15s ease}.btn:active,.hub-tile:active,.nav-item:active,.pill:active,.sb-item:active,.sb-logout:active{transform:scale(.97)}.hub-tile:active{transform:scale(.985)}.table tbody tr{will-change:background-color}@media (max-width:640px){.hub{padding:12px}.hub-head{margin-bottom:8px}.hub-head h1{font-size:18px}.hub-head .sub{font-size:12px}.hub-grid{grid-template-columns:repeat(3,1fr);gap:8px}.hub-tile{min-height:0;padding:12px 6px;gap:3px;align-items:center;text-align:center}.hub-ic{font-size:22px}.hub-t{font-size:12px;line-height:1.2}.hub-d{display:none}}.cal-nav{gap:10px}.cal-nav button{padding:8px 14px;min-height:40px}.cal-nav button:hover{background:var(--surface-2,#f1f4f8)}.cal-nav .cal-title{color:var(--text,#1f2937)}.cost-total{background:linear-gradient(135deg,#2f6f6a,#245955);color:#fff;border:none}.cost-total-label{font-size:13px;opacity:.9}.cost-total-num{font-size:34px;font-weight:800;letter-spacing:.5px;margin:4px 0 6px;line-height:1.1}.cost-total-sub{font-size:12.5px;opacity:.92}.cost-day{display:grid;grid-template-columns:88px 1fr 110px;align-items:center;grid-gap:10px;gap:10px;padding:6px 2px;border-bottom:1px solid var(--line,#eef1f5)}.cost-day:last-child{border-bottom:none}.cost-day-d{font-size:12.5px;color:var(--muted,#5b6573)}.cost-day-bar{height:10px;background:var(--surface-2,#eef1f5);border-radius:6px;overflow:hidden}.cost-day-bar>span{display:block;height:100%;background:#2f6f6a;border-radius:6px}.cost-day-v{font-size:13px;font-weight:700;text-align:right;color:var(--text,#1f2937)}@media (max-width:640px){.cost-total-num{font-size:28px}.cost-day{grid-template-columns:70px 1fr 92px;gap:6px}}.wo-filterbar{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-bottom:12px}.set-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:14px;gap:14px;margin-bottom:14px;align-items:start}.role-list{display:grid;grid-template-columns:repeat(3,1fr);grid-gap:10px;gap:10px}.role-item{border:1px solid var(--line,#d3d9e2);border-radius:10px;padding:11px 12px;background:#fbfcfe}.role-item.is-current{border-color:var(--brand-300,#9db4d0);background:#eef4fb;box-shadow:inset 3px 0 0 var(--brand,#1f3a5f)}.role-head{display:flex;align-items:center;flex-wrap:wrap;gap:6px;margin-bottom:6px}.role-head strong{font-size:14px;color:var(--text,#1f2937)}.role-key{font-size:11px;color:var(--muted,#5b6573)}.role-scope{font-size:12.5px;color:var(--text,#1f2937);line-height:1.55;margin-bottom:4px}.role-note{font-size:11.5px;color:var(--muted,#5b6573);line-height:1.5}@media (max-width:900px){.role-list{grid-template-columns:1fr}}@media (max-width:640px){.set-grid{grid-template-columns:1fr;gap:12px;margin-bottom:12px}}.page-topbar{display:flex;align-items:center;justify-content:space-between;gap:8px;padding:8px 0 4px}.topbtn{display:inline-flex;align-items:center;gap:6px;min-height:38px;padding:7px 14px;border:1px solid var(--line,#d3d9e2);background:#fff;border-radius:9px;font-weight:700;font-size:13px;cursor:pointer;color:var(--text,#1f2937)}.topbtn:hover{background:var(--surface-2,#f1f4f8)}.topbtn.bell{position:relative;min-width:42px;justify-content:center;font-size:16px}.bell-n{position:absolute;top:-5px;right:-5px;min-width:18px;height:18px;padding:0 4px;box-sizing:border-box;background:#c2261b;color:#fff;border-radius:999px;font-size:11px;font-weight:800;line-height:18px;text-align:center}.rev-strip{display:flex;align-items:center;flex-wrap:wrap;gap:8px;background:#eef6f4;border:1px solid #cfe5e0;border-radius:10px;padding:9px 14px;margin-bottom:12px;font-size:13px;color:var(--text,#1f2937)}.rev-strip strong{font-size:18px;color:#143f3a}.rev-strip .muted{font-size:11px}.site-card-meta{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.rev-badge{font-size:12px;font-weight:700;color:#143f3a;background:#dbeee9;border:1px solid #b6d8d0;border-radius:999px;padding:2px 8px;white-space:nowrap}.ack-tag{display:inline-block;margin-left:3px;font-size:11px;line-height:1}.ack-tag.ok{color:#1e7d46}.ack-tag.pd{color:#9aa3af}.ack-tag.od{color:#c2261b}.notif-list{display:flex;flex-direction:column;gap:2px}.notif-item{display:flex;gap:10px;padding:10px 6px;border-bottom:1px solid var(--line,#eef1f5);align-items:flex-start}.notif-item:last-child{border-bottom:none}.notif-item.unread{background:#f3f8ff}.notif-dot{width:9px;height:9px;border-radius:50%;margin-top:5px;flex:0 0 auto}.notif-dot.ok{background:#1e7d46}.notif-dot.warn{background:#d98324}.notif-body{display:flex;flex-direction:column;gap:2px;min-width:0;flex:1 1}.notif-text{font-size:13px;line-height:1.5;color:var(--text,#1f2937)}.notif-at{font-size:11px;color:var(--muted,#5b6573);margin-top:2px}@media (max-width:640px){.page-topbar{padding:6px 0 2px;gap:6px}.topbtn{padding:6px 10px;font-size:12px;min-height:36px}.topbtn.bell{min-width:38px}.rev-strip{padding:8px 10px;font-size:12px}.rev-strip strong{font-size:16px}.page{padding:12px 10px 28px}.page-head{margin-bottom:10px}.page-head h1{font-size:17px}.page-head .sub{font-size:12px;line-height:1.5}.page-head .actions{width:100%;display:flex;flex-wrap:wrap;gap:8px;margin-top:8px}.page-head .actions .btn{flex:1 1 auto}.card{padding:12px;border-radius:12px}.card-head{gap:6px;margin-bottom:8px}.card-head h2{font-size:14px}.card-head h3{font-size:13px}.card-head .sub{font-size:11.5px}.table{font-size:12.5px}.table thead th{padding:7px 9px}.table tbody td{padding:5px 9px;line-height:1.3}.table tbody td .muted{font-size:10.5px!important;line-height:1.15}.table-wrap{max-height:64vh}.dt-toolbar{gap:6px}.dt-search{flex:1 1 100%;min-width:0}.dt-filter{flex-grow:1;flex-shrink:1;flex-basis:calc(50% - 4px);min-width:0}.dt-extra{flex:1 1 100%}.dt-extra .btn{width:100%;box-sizing:border-box}.dt-clear{flex:0 0 auto}.dt-count{flex-basis:100%;text-align:right;margin:0}.row.tight{gap:6px}.pill{min-height:36px}.board-sites{grid-template-columns:1fr;gap:10px}.site-card-head{margin-bottom:6px;padding-bottom:6px}.post-row{padding:5px 0}.slot-chip{font-size:11px}.mini-row{padding:7px 6px}.kv dt{font-size:11px}.kv dd{font-size:13px}}@media (max-width:380px){.page{padding:10px 8px 24px}.table{font-size:12px}.table tbody td,.table thead th{padding:5px 7px}}.staff-body{background:#dfe4ea;min-height:100vh}.sauth-wrap,.staff-app{max-width:480px;margin:0 auto;min-height:100vh;background:var(--bg,#eef1f5);box-shadow:0 0 30px rgba(0,0,0,.12);position:relative;display:flex;flex-direction:column}.sauth-wrap{justify-content:center;padding:24px 18px}.sauth-card{background:#fff;border-radius:16px;padding:22px;box-shadow:0 10px 30px rgba(0,0,0,.1)}.sauth-brand{display:flex;align-items:center;gap:12px;margin-bottom:18px}.sauth-mark{width:44px;height:44px;border-radius:12px;background:#2a6048;color:#fff;display:grid;place-items:center;font-weight:800;font-size:20px}.sauth-title{font-weight:800;font-size:16px;color:var(--text,#1f2937)}.sauth-sub{font-size:12px;color:var(--muted,#5b6573)}.sauth-tabs{display:flex;gap:6px;margin-bottom:14px;background:#eef1f5;padding:4px;border-radius:10px}.sauth-tab{flex:1 1;border:0;background:transparent;padding:9px;border-radius:8px;font-weight:700;font-size:13px;color:var(--muted,#5b6573);cursor:pointer}.sauth-tab.active{background:#fff;color:#2a6048;box-shadow:0 1px 4px rgba(0,0,0,.1)}.sauth-note{font-size:13px;color:var(--muted,#5b6573);margin:0 0 12px}.sauth-go{width:100%;margin-top:12px;padding:13px;font-size:15px}.sauth-err{color:var(--danger,#c2261b);font-size:13px;min-height:18px;margin:8px 0 0}.sauth-hint{font-size:11px;color:var(--muted,#5b6573);margin:10px 0 0}.chk-grid{display:grid;grid-template-columns:1fr 1fr;grid-gap:6px;gap:6px}.chk{font-size:13px;gap:6px;padding:6px;border:1px solid var(--line,#d3d9e2);border-radius:8px}.chk,.field{display:flex}.field{flex-direction:column;gap:5px;margin-bottom:12px}.field label{font-size:12px;font-weight:700;color:var(--muted,#5b6573)}.input,.select{padding:11px 12px;border:1px solid var(--line,#d3d9e2);border-radius:10px;font-size:16px;background:#fff;width:100%;box-sizing:border-box}.staff-hdr{position:-webkit-sticky;position:sticky;top:0;z-index:40;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:#2a6048;color:#fff}.staff-hdr-name{font-weight:700;font-size:15px}.hdr-ic-btn{background:transparent;border:0;padding:0;cursor:pointer}.hdr-ic{width:34px;height:34px;border-radius:50%;object-fit:cover;display:block;border:2px solid hsla(0,0%,100%,.6)}.hdr-ic-ph{display:grid;place-items:center;background:#fff;color:#2a6048;font-weight:800}.staff-main{padding:16px 16px 88px}.tabbar{position:-webkit-sticky;position:sticky;bottom:0;z-index:40;display:grid;grid-template-columns:repeat(4,1fr);background:#fff;border-top:1px solid var(--line,#d3d9e2)}.tabbar-item{background:transparent;border:0;padding:8px 4px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:2px;color:var(--muted,#5b6573)}.tabbar-item.active{color:#2a6048}.tabbar-ic{font-size:20px;line-height:1}.tabbar-l{font-size:11px;font-weight:700}.punch-current{background:#fff;border:1px solid var(--line,#d3d9e2);border-radius:14px;padding:16px;margin-bottom:18px}.punch-current .pc-label{font-size:12px;color:var(--muted,#5b6573)}.punch-current .pc-site{font-size:18px;font-weight:800;color:var(--text,#1f2937);margin:2px 0}.punch-current .pc-time{font-size:14px;color:var(--text,#1f2937)}.punch-wrap{display:grid;place-items:center;padding:12px 0 24px}.punch-btn{width:220px;height:220px;border-radius:50%;border:0;cursor:pointer;color:#fff;font-size:30px;font-weight:800;box-shadow:0 10px 30px rgba(0,0,0,.18);display:grid;place-items:center;grid-gap:4px;gap:4px}.punch-btn .pb-sub{font-size:13px;font-weight:600;opacity:.9}.punch-btn.in{background:radial-gradient(circle at 50% 35%,#36a05f,#1e7d46)}.punch-btn.out{background:radial-gradient(circle at 50% 35%,#d9534f,#c2261b)}.punch-btn:active{transform:scale(.97)}.punch-done{text-align:center;color:var(--muted,#5b6573)}.seg{display:flex;gap:4px;background:#eef1f5;padding:4px;border-radius:10px;margin-bottom:12px}.seg button{flex:1 1;border:0;background:transparent;padding:8px;border-radius:8px;font-weight:700;font-size:13px;color:var(--muted,#5b6573);cursor:pointer}.seg button.active{background:#fff;color:#2a6048;box-shadow:0 1px 3px rgba(0,0,0,.1)}.cal-nav{display:flex;align-items:center;justify-content:space-between;margin-bottom:10px}.cal-nav button{border:1px solid var(--line,#d3d9e2);background:#fff;border-radius:8px;padding:6px 12px;cursor:pointer;font-weight:700}.cal-nav .cal-title{font-weight:800}.tt-wrap{overflow-x:auto;border:1px solid var(--line,#d3d9e2);border-radius:10px;background:#fff}.tt{display:grid;grid-template-columns:44px repeat(7,minmax(40px,1fr));min-width:360px}.tt-cell{border-right:1px solid #eef1f5;border-bottom:1px solid #eef1f5;min-height:22px;font-size:11px;position:relative}.tt-head{position:-webkit-sticky;position:sticky;top:0;background:#f3f6fa;text-align:center;font-weight:700;padding:6px 0;z-index:1}.tt-hour{text-align:right;padding:0 4px;color:var(--muted,#5b6573);font-size:10px;background:#fafbfc}.tt-shift{background:#2a6048;color:#fff;border-radius:4px;font-size:10px;padding:1px 3px;position:absolute;left:1px;right:1px;overflow:hidden}.tt-shift.is-tap{cursor:pointer}.todaycard{background:#fff;border:1px solid var(--line,#d3d9e2);border-radius:12px;padding:14px;margin-bottom:10px}.todaycard.is-today{border-left:4px solid #2a6048}.todaycard .tc-when{font-size:12px;color:var(--muted,#5b6573)}.todaycard .tc-site{font-weight:800;font-size:16px;margin:2px 0}.todaycard .tc-empty{color:var(--muted,#5b6573)}.shift-day{background:#fff;border:1px solid var(--line,#d3d9e2);border-radius:12px;padding:12px;margin-bottom:10px}.shift-day-h{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.shift-day-date{font-weight:800}.avail-seg{display:flex;gap:4px;flex-wrap:wrap}.avail-seg button{border:1px solid var(--line,#d3d9e2);background:#fff;border-radius:999px;padding:6px 12px;font-size:13px;cursor:pointer}.avail-seg button.on-ok{background:#1e7d46;color:#fff;border-color:#1e7d46}.avail-seg button.on-none{background:#5b6573;color:#fff;border-color:#5b6573}.avail-seg button.on-tbd{background:#b15c00;color:#fff;border-color:#b15c00}.avail-seg button.on-consult{background:#1f3a5f;color:#fff;border-color:#1f3a5f}.band-row{margin-top:8px;display:flex;gap:4px;flex-wrap:wrap}.band-row button{border:1px solid var(--line,#d3d9e2);background:#fff;border-radius:8px;padding:5px 10px;font-size:12px;cursor:pointer}.band-row button.active{background:#2a6048;color:#fff;border-color:#2a6048}.sticky-actions{position:-webkit-sticky;position:sticky;bottom:0;background:var(--bg,#eef1f5);padding:10px 0;display:flex;gap:8px}.sticky-actions .btn{flex:1 1;padding:13px;font-size:15px}.submit-badge{font-size:12px}.wk-nav{gap:8px}.wk-nav button{font-size:13px;white-space:nowrap}.wk-pills{display:flex;gap:8px;overflow-x:auto;padding:2px 0 8px;-webkit-overflow-scrolling:touch}.wk-pill{flex:0 0 auto;border:1px solid var(--line,#d3d9e2);background:#fff;border-radius:12px;padding:8px 10px;cursor:pointer;display:flex;flex-direction:column;align-items:center;gap:4px;min-width:76px}.wk-pill.active{border-color:#2a6048;box-shadow:inset 0 0 0 1px #2a6048}.wk-pill-d{font-weight:800;font-size:13px;color:var(--text,#1f2937);white-space:nowrap}.wk-status{font-size:13px;color:var(--muted,#5b6573);margin:4px 0 10px;display:flex;align-items:center;gap:6px}.shift-lock{background:#fdecea;border:1px solid #f1c4c0;border-radius:10px;padding:10px 12px;font-size:13px;font-weight:700;margin-bottom:10px}.shift-day.is-weekend .shift-day-date,.shift-lock{color:#c2261b}.shift-day-band{font-size:12px;color:#2a6048;font-weight:700}.avail-seg button{flex:1 1;min-width:0;text-align:center}.band-row button{display:inline-flex;flex-direction:column;align-items:center;line-height:1.25;gap:1px}.band-row .band-sub{font-size:10px;opacity:.8;font-weight:600}.band-custom{margin-top:8px;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.band-custom label{font-size:12px;font-weight:700;color:var(--muted,#5b6573)}.band-custom .select.sm{width:auto;flex:1 1;min-width:84px;padding:8px 10px;font-size:14px}.band-custom .band-dash{color:var(--muted,#5b6573)}.tpl-card .tpl-save{margin-bottom:6px}.tpl-list{display:flex;flex-direction:column;gap:6px}.tpl-row{display:flex;align-items:center;gap:8px;padding:8px;border:1px solid var(--line,#d3d9e2);border-radius:10px}.tpl-name{flex:1 1;font-weight:700;font-size:13px;min-width:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.tpl-acts{display:flex;gap:4px;flex-shrink:0}.tpl-empty,.tpl-note{font-size:12px;color:var(--muted,#5b6573);margin:6px 0 0}.ss-toast{position:fixed;left:50%;bottom:96px;transform:translateX(-50%);max-width:88%;background:#1f2937;color:#fff;padding:10px 16px;border-radius:999px;font-size:13px;font-weight:700;box-shadow:0 8px 24px rgba(0,0,0,.25);z-index:80;text-align:center}.mypage-top{display:flex;align-items:center;gap:14px;background:#fff;border:1px solid var(--line,#d3d9e2);border-radius:14px;padding:16px;margin-bottom:14px}.mypage-ic{width:64px;height:64px;border-radius:50%;object-fit:cover;border:2px solid var(--line,#d3d9e2)}.mypage-ic-ph{display:grid;place-items:center;background:#2a6048;color:#fff;font-weight:800;font-size:26px}.mp-name{font-weight:800;font-size:17px}.mp-code{font-size:12px;color:var(--muted,#5b6573)}.mp-ic-btn{position:relative;background:transparent;border:0;padding:0;cursor:pointer;flex:0 0 auto}.mp-ic-edit{position:absolute;left:0;right:0;bottom:-4px;margin:0 auto;width:max-content;background:#2a6048;color:#fff;font-size:10px;font-weight:700;padding:2px 8px;border-radius:999px;line-height:1.4}.mp-id{min-width:0}.mp-kv dd{word-break:break-word}.mp-quals{display:flex;flex-wrap:wrap;gap:4px}.mp-edit-btn{margin-top:12px;width:100%;box-sizing:border-box}.mp-logout{margin-top:18px}.btn{display:inline-grid;place-items:center;border:1px solid var(--line,#d3d9e2);background:#fff;color:var(--text,#1f2937);border-radius:10px;padding:10px 14px;font-weight:700;cursor:pointer;font-size:14px}.btn-primary{background:#2a6048;color:#fff;border-color:#2a6048}.btn-ghost{background:transparent}.btn-danger{background:var(--danger,#c2261b);color:#fff;border-color:var(--danger,#c2261b)}.btn.sm{padding:6px 10px;font-size:12px}.btn[disabled]{opacity:.5;cursor:not-allowed}@keyframes page-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:none}}.staff-main{animation:page-in .26s cubic-bezier(.32,.72,0,1)}.auth-tab,.avail-seg button,.band-row button,.btn,.pill,.seg button,.shift-day,.tabbar-item,.todaycard,.tt-shift{transition:background-color .15s ease,color .15s ease,transform .12s cubic-bezier(.32,.72,0,1),box-shadow .18s ease,border-color .15s ease}.avail-seg button:active,.band-row button:active,.btn:active,.pill:active,.seg button:active,.tabbar-item:active,.todaycard:active{transform:scale(.97)}.avail-seg button,.band-row button,.btn.sm,.nav-user-sel,.seg button{min-height:44px}.avail-seg button{padding:10px 14px}.band-row button{padding:10px 12px}.chk{min-height:44px;align-items:center}.hdr-ic-btn{min-width:44px;display:grid;place-items:center}.cal-nav button,.hdr-ic-btn,.seg button{min-height:44px}.tt-shift{min-height:30px}@media (max-height:720px){.staff-main{padding:12px 12px 80px}.punch-btn{width:168px;height:168px;font-size:26px}.punch-wrap{padding:6px 0 12px}.punch-current{padding:12px;margin-bottom:12px}}.ack-banner{background:#fdeceb;border:1px solid #f3b8b2;color:#9e1c14;border-radius:10px;padding:10px 12px;font-weight:700;font-size:13px;line-height:1.5}.ack-banner,.ack-card{margin-bottom:12px}.ack-card .mini-row{min-height:48px}.ack-card .mini-row .btn.sm{min-height:40px}.err{color:var(--danger,#c2261b);margin:8px 0 0;min-height:18px}.banner,.err{font-size:13px}.banner{background:#fff6e8;border:1px solid #f3d4ab;border-radius:10px;padding:12px 14px;margin-bottom:14px;line-height:1.7}.banner a{color:var(--brand,var(--brand));font-weight:700}.fgrid2{grid-template-columns:1fr 1fr;grid-gap:12px}.fgrid2,.fgrid3{display:grid;gap:12px}.fgrid3{grid-template-columns:1fr 1fr 1fr;grid-gap:12px}@media (max-width:640px){.fgrid2,.fgrid3{grid-template-columns:1fr}}a.btn{text-decoration:none;display:inline-flex;align-items:center;justify-content:center}form.inline{display:inline;margin:0}.sauth-wrap{min-height:100dvh}.staff-body{height:100dvh;overflow:hidden}.staff-app{height:100dvh;min-height:0}.staff-app .tabbar{position:static;flex:0 0 auto}.table-wrap,.ui-panel-body{-webkit-overflow-scrolling:touch}@media (prefers-reduced-motion:no-preference){.ui-drawer,.ui-modal{will-change:transform,opacity}}.btn-spin{width:14px;height:14px;border-radius:50%;display:inline-block;margin-right:6px;border:2px solid hsla(0,0%,100%,.35);border-top-color:#fff;animation:spin .7s linear infinite;vertical-align:-2px}.btn.btn-ghost .btn-spin{border-color:rgba(12,144,152,.3);border-top-color:var(--brand,var(--brand))}@keyframes spin{to{transform:rotate(1turn)}}.skel-wrap{display:grid;grid-gap:12px;gap:12px}.skel{background:linear-gradient(90deg,#e9edf2 25%,#f4f6f9 37%,#e9edf2 63%);background-size:400% 100%;animation:skel 1.2s ease infinite;border-radius:12px}@keyframes skel{0%{background-position:100% 50%}to{background-position:0 50%}}@media (prefers-reduced-motion:reduce){.skel{animation:none}}.ui-modal.xl{width:min(1080px,100%)}.bigcal{max-width:860px;margin:0 auto}.bigcal-nav{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:10px}.bigcal-title{font-weight:800;font-size:18px}.bigcal-grid{display:grid;grid-template-columns:repeat(7,1fr);grid-gap:6px;gap:6px}.bigcal-head{margin-bottom:4px}.bigcal-h{text-align:center;font-size:13px;font-weight:700;color:var(--muted,#5b6573);padding:4px 0}.bigcal-h.sun{color:#c2261b}.bigcal-h.sat{color:#2563a8}.bigcal-cell{position:relative;min-height:64px;border:1px solid var(--line,#d3d9e2);border-radius:10px;background:#fff;cursor:pointer;display:flex;align-items:flex-start;justify-content:flex-start;padding:6px 8px;font-size:15px;transition:background .12s ease,border-color .12s ease,transform .08s ease}.bigcal-cell:hover{background:#eef4fb;border-color:#9db4d0}.bigcal-cell:active{transform:scale(.97)}.bigcal-cell.empty{background:transparent;border-color:transparent;cursor:default}.bigcal-cell.on{background:var(--brand,var(--brand));border-color:var(--brand,var(--brand))}.bigcal-cell.on .bigcal-d{color:#fff}.bigcal-cell.sun .bigcal-d{color:#c2261b}.bigcal-cell.sat .bigcal-d{color:#2563a8}.bigcal-cell.on.sat .bigcal-d,.bigcal-cell.on.sun .bigcal-d{color:#fff}.bigcal-cell.today{box-shadow:inset 0 0 0 2px var(--brand,var(--brand))}.bigcal-d{font-weight:700}.bigcal-check{position:absolute;right:8px;bottom:6px;color:#fff;font-weight:800;font-size:14px}.bigcal-tools{display:flex;flex-direction:column;gap:10px;margin-top:14px;padding-top:12px;border-top:1px solid var(--line,#eef1f5)}.bigcal-tool{display:flex;align-items:center;gap:8px;flex-wrap:wrap}.bigcal-tlabel{font-size:12px;font-weight:700;color:var(--muted,#5b6573);min-width:108px}.bigcal-tool .input[type=date]{max-width:160px}.bigcal-dows{display:inline-flex;gap:5px;flex-wrap:wrap}.bigcal-dow{min-width:40px;min-height:40px;border:1px solid var(--line,#d3d9e2);background:#fff;border-radius:8px;cursor:pointer;font-weight:700;font-size:13px}.bigcal-dow.on{background:var(--brand,var(--brand));color:#fff;border-color:var(--brand,var(--brand))}.bigcal-chips{display:flex;flex-wrap:wrap;gap:6px;align-items:center;margin-top:12px}.bigcal-count{font-size:12.5px;font-weight:800;color:var(--brand,var(--brand))}.md-chip{display:inline-flex;align-items:center;gap:2px;background:#e8eef6;border:1px solid #c9d8ea;border-radius:999px;padding:3px 4px 3px 10px;font-size:12px}.md-chip button{border:0;background:transparent;cursor:pointer;font-size:15px;line-height:1;color:var(--muted,#5b6573);padding:0 4px;min-width:26px;min-height:26px}.md-chip button:hover{color:var(--danger,#c2261b)}@media (max-width:640px){.bigcal-cell{min-height:52px;padding:4px 6px;font-size:14px;border-radius:8px}.bigcal-grid{gap:4px}.bigcal-tlabel{min-width:100%}}.table tr.is-clickable td{cursor:pointer}.sched-modes{display:flex;gap:6px;flex-wrap:wrap}.sched-mode{flex:1 1 auto;min-height:46px;min-width:64px;border-radius:10px;border:2px solid var(--line,#d3d9e2);background:#fff;font-weight:800;font-size:14px;cursor:pointer;transition:transform .08s ease}.sched-mode:active{transform:scale(.96)}.sched-mode.m-ok{color:#1e7d46}.sched-mode.m-ok.on{background:#1e7d46;color:#fff;border-color:#1e7d46}.sched-mode.m-none{color:#5b6573}.sched-mode.m-none.on{background:#5b6573;color:#fff;border-color:#5b6573}.sched-mode.m-tbd{color:#b15c00}.sched-mode.m-tbd.on{background:#d98324;color:#fff;border-color:#d98324}.sched-mode.m-consult{color:var(--brand)}.sched-mode.m-consult.on{background:var(--brand);color:#fff;border-color:var(--brand)}.sched-mode.m-erase.on{background:#eef1f5;border-color:#9aa3af}.sched-cell.st-ok{background:#1e7d46;border-color:#1e7d46}.sched-cell.st-ok .bigcal-d,.sched-cell.st-ok .sched-st{color:#fff}.sched-cell.st-none{background:#e7ebf0;border-color:#cfd6df}.sched-cell.st-none .sched-st{color:#5b6573}.sched-cell.st-tbd{background:#fdf0e0;border-color:#f3d4ab}.sched-cell.st-tbd .sched-st{color:#b15c00}.sched-cell.st-consult{background:#e8eef6;border-color:#c9d8ea}.sched-cell.st-consult .sched-st{color:var(--brand)}.sched-st{position:absolute;right:6px;bottom:4px;font-size:11px;font-weight:800}.sched-legend{display:flex;gap:14px;flex-wrap:wrap;margin-top:10px;font-size:12px;color:var(--muted,#5b6573)}.sched-legend .sw{display:inline-block;width:12px;height:12px;border-radius:3px;margin-right:4px;vertical-align:-1px}.sched-legend .sw.st-ok{background:#1e7d46}.sched-legend .sw.st-none{background:#cfd6df}.sched-legend .sw.st-tbd{background:#f3d4ab}.sched-legend .sw.st-consult{background:#c9d8ea}.sched-legend span{display:inline-flex;align-items:center}.cal-cell.selday{box-shadow:inset 0 0 0 2px var(--brand,var(--brand))}button.punch-current.is-tappable{display:block;width:100%;text-align:left;cursor:pointer;font:inherit;color:inherit;border:1px solid var(--line,#d3d9e2)}button.punch-current.is-tappable:active{transform:scale(.99)}.pc-hint{margin-top:6px;font-size:11.5px;color:var(--brand,var(--brand));font-weight:700}button.is-tappable-row{display:flex;width:100%;align-items:center;gap:8px;background:transparent;border:0;padding:10px 6px;border-bottom:1px solid var(--line,#eef1f5);font:inherit;color:inherit;cursor:pointer;min-height:48px}button.is-tappable-row:last-child{border-bottom:0}button.is-tappable-row:active{background:#eef4fb}.staff-main{flex:1 1;min-height:0;overflow-y:auto;padding:10px 12px 14px}.page-head.compact{margin-bottom:6px}.punch-current{margin-bottom:10px}.others-card{padding:10px 12px;margin-top:10px}@media (max-height:760px){.punch-btn{width:168px;height:168px;font-size:30px}.punch-wrap{padding:4px 0 8px}.punch-current{padding:12px}.staff-hdr{padding-top:8px;padding-bottom:8px}}.wk2-wrap{background:#fff;border:1px solid #dadce0;border-radius:12px;overflow:hidden}.wk2-headrow{display:grid;grid-template-columns:38px repeat(7,minmax(0,1fr));border-bottom:1px solid #dadce0}.wk2-corner{background:#fff}.wk2-dayhead{display:flex;flex-direction:column;align-items:center;padding:6px 0 5px;gap:1px;color:#3c4043}.wk2-dayhead .wk2-dow{font-size:10.5px;color:#70757a;font-weight:600}.wk2-dayhead .wk2-dnum{font-size:15px;font-weight:700;width:26px;height:26px;display:grid;place-items:center;border-radius:50%}.wk2-dayhead.today .wk2-dnum{background:#1a73e8}.wk2-dayhead.sun .wk2-dnum,.wk2-dayhead.sun .wk2-dow{color:#d93025}.wk2-dayhead.sat .wk2-dnum,.wk2-dayhead.sat .wk2-dow{color:#1a73e8}.wk2-dayhead.today.sat .wk2-dnum,.wk2-dayhead.today.sun .wk2-dnum{color:#fff}.wk2-body{display:grid;grid-template-columns:38px repeat(7,minmax(0,1fr))}.wk2-hours{position:relative}.wk2-hour{position:absolute;right:4px;transform:translateY(-50%);font-size:9.5px;color:#70757a}.wk2-col{position:relative;border-left:1px solid #e8eaed;background-image:repeating-linear-gradient(180deg,transparent 0,transparent 33px,#f1f3f4 0,#f1f3f4 34px)}.wk2-col.today{background-color:#f8fbff}.wk2-block{position:absolute;left:2px;right:2px;background:#1a73e8;border-radius:6px;color:#fff;padding:2px 4px;overflow:hidden;display:flex;flex-direction:column;gap:0;box-shadow:0 1px 2px rgba(0,0,0,.18)}.wk2-block:active{opacity:.85}.wk2-bt{font-size:9px;font-weight:700;opacity:.92;line-height:1.2}.wk2-bs{font-size:10px;font-weight:700;line-height:1.25;overflow:hidden;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.sched-time{display:block;font-size:9px;font-weight:700;opacity:.9}button.site-link{background:transparent;border:0;padding:0;font:inherit;cursor:pointer;color:inherit;text-align:left}button.site-link .site-name,button.site-link strong{-webkit-text-decoration:underline dotted rgba(12,144,152,.5);text-decoration:underline dotted rgba(12,144,152,.5);text-underline-offset:3px}button.site-link:active{opacity:.7}:root{--brand:#0c9098;--brand-700:#077d83;--brand-300:#58b5ba;--brand-tint:#e6f4f5;--accent-red:#e90000}.auth-wrap{background:linear-gradient(160deg,#0c9098,#066d73)}.staff-hdr{background:var(--brand)}.hdr-ic-ph,.tabbar-item.active{color:var(--brand)}.sauth-mark{background:var(--brand)}.sauth-tab.active,.seg button.active{color:var(--brand)}.tt-shift{background:var(--brand)}.todaycard.is-today{border-left-color:var(--brand)}.punch-btn.in{background:radial-gradient(circle at 50% 35%,#15aeb6,#0a8e96)}.wk2-block{background:var(--brand)}.wk2-dayhead.today .wk2-dnum{background:var(--brand);color:#fff}.cal-gc .cal-cell.is-today .cal-d{background:var(--brand)}.gc-ev.neutral{background:#e0f2f3;color:#066d73}.ui-scrolltop:hover{background:var(--brand-700)}.rev-badge,.rev-strip strong{color:#066d73}.badge-warn{background:#fff3df;color:#9a5b00;border:1px solid #f3d28b}.member-list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:6px}.member-list .member{display:flex;align-items:center;justify-content:space-between;padding:8px 10px;border:1px solid #e6e9ef;border-radius:8px;background:#fff;font-size:14px}.member-list .member.is-me{background:var(--brand-tint);border-color:var(--brand-300)}.member-list .member-name{font-weight:600}.sb-item{position:relative}.sb-badge{display:inline-grid;place-items:center;min-width:18px;height:18px;padding:0 5px;margin-left:auto;border-radius:999px;background:var(--accent-red,#e90000);color:#fff;font-size:11px;font-weight:800;line-height:1}.mb-bell{display:inline-flex;align-items:center;gap:2px;margin-left:auto;font-size:18px}.hamburger,.mb-bell{position:relative}.hb-dot{position:absolute;top:4px;right:4px;width:9px;height:9px;border-radius:50%;background:var(--accent-red,#e90000);border:2px solid #fff}.ngpair-box{max-height:180px;overflow-y:auto;border:1px solid #e6e9ef;border-radius:8px;padding:6px 8px;display:flex;flex-direction:column;gap:2px;background:#fbfbfd}.ngpair-item{display:flex;align-items:center;gap:8px;padding:4px 2px;font-size:13px;cursor:pointer}.ngpair-item input{flex:none}.ack-mark{font-size:10px;font-weight:800;padding:1px 5px;border-radius:999px;margin-left:4px}.ack-mark.pending{background:#fff3df;color:#9a5b00}.ack-mark.rejected{background:#fde8e6;color:#b3261e}.slot-chip.is-rejected{outline:1px solid #f3b4ad}.gc-ev.pend{background:#ffce80;color:#6b4400;font-weight:700}.wk2-block.is-pending{background:#e8920c;box-shadow:inset 0 0 0 2px #b96f00}