:root{--accent: #0e7c6b;--accent-ink: #0a5c50;--accent-soft: color-mix(in oklch, var(--accent) 12%, white);--accent-softer: color-mix(in oklch, var(--accent) 7%, white);--canvas: #f6f6f3;--surface: #ffffff;--surface-2: #fbfbf9;--sidebar: #ffffff;--ink: #1c2230;--ink-2: #424a5c;--ink-3: #6b7383;--ink-4: #9aa1ae;--line: #e8e8e2;--line-2: #f0f0eb;--ok: #1f9d6b;--ok-soft: #e6f5ee;--warn: #c98a12;--warn-soft: #fcf2dd;--danger: #d65151;--danger-soft: #fbeaea;--info: #3a76d8;--info-soft: #e8f0fc;--violet: #7a5ae0;--violet-soft: #efeafc;--r-sm: 7px;--r: 11px;--r-lg: 16px;--r-xl: 22px;--shadow-sm: 0 1px 2px rgba(28,34,48,.05), 0 1px 1px rgba(28,34,48,.03);--shadow: 0 2px 8px rgba(28,34,48,.06), 0 1px 2px rgba(28,34,48,.04);--shadow-lg: 0 16px 40px rgba(28,34,48,.13), 0 4px 12px rgba(28,34,48,.07);--pad: 22px;--row-h: 56px;--gap: 18px;--sidebar-w: 248px;font-family:Hanken Grotesk,system-ui,sans-serif}[data-density=compact]{--pad: 15px;--row-h: 46px;--gap: 12px}[data-density=comfy]{--pad: 28px;--row-h: 64px;--gap: 24px}[data-theme=dark]{--canvas: #14171d;--surface: #1b1f27;--surface-2: #20242d;--sidebar: #181b22;--ink: #eef0f4;--ink-2: #c2c7d0;--ink-3: #8b93a1;--ink-4: #646b78;--line: #2a2f39;--line-2: #232831;--accent-soft: color-mix(in oklch, var(--accent) 22%, #1b1f27);--accent-softer: color-mix(in oklch, var(--accent) 13%, #1b1f27);--ok-soft: color-mix(in oklch, var(--ok) 18%, #1b1f27);--warn-soft: color-mix(in oklch, var(--warn) 18%, #1b1f27);--danger-soft: color-mix(in oklch, var(--danger) 18%, #1b1f27);--info-soft: color-mix(in oklch, var(--info) 18%, #1b1f27);--violet-soft: color-mix(in oklch, var(--violet) 18%, #1b1f27);--shadow-sm: 0 1px 2px rgba(0,0,0,.3);--shadow: 0 2px 10px rgba(0,0,0,.35);--shadow-lg: 0 20px 50px rgba(0,0,0,.55)}*{box-sizing:border-box}html,body{margin:0;padding:0;height:100%}body{background:var(--canvas);color:var(--ink);font-family:Hanken Grotesk,system-ui,sans-serif;-webkit-font-smoothing:antialiased;font-size:14px;line-height:1.5;letter-spacing:-.005em}.mono{font-family:Geist Mono,ui-monospace,SF Mono,monospace;font-feature-settings:"tnum" 1;letter-spacing:-.02em}::selection{background:var(--accent-soft)}*::-webkit-scrollbar{width:11px;height:11px}*::-webkit-scrollbar-thumb{background:color-mix(in oklch,var(--ink-4) 45%,transparent);border-radius:99px;border:3px solid transparent;background-clip:padding-box}*::-webkit-scrollbar-thumb:hover{background:color-mix(in oklch,var(--ink-4) 70%,transparent);background-clip:padding-box}.app{display:flex;height:100vh;overflow:hidden}.sidebar{width:var(--sidebar-w);flex:0 0 var(--sidebar-w);background:var(--sidebar);border-right:1px solid var(--line);display:flex;flex-direction:column;transition:width .22s cubic-bezier(.4,0,.2,1),flex-basis .22s cubic-bezier(.4,0,.2,1);overflow:hidden}.sidebar.collapsed{--sidebar-w: 74px}.main{flex:1;min-width:0;display:flex;flex-direction:column;overflow:hidden}.content{flex:1;overflow-y:auto;overflow-x:hidden}.content-inner{padding:26px 34px 64px;max-width:1320px;margin:0 auto}[data-density=compact] .content-inner{padding:18px 24px 48px}.brand{display:flex;align-items:center;gap:11px;padding:19px 20px 16px;min-height:64px}.brand-mark{width:34px;height:34px;border-radius:9px;background:var(--accent);display:grid;place-items:center;flex:0 0 34px;box-shadow:0 2px 8px color-mix(in oklch,var(--accent) 40%,transparent)}.brand-mark svg{width:19px;height:19px}.brand-mark--logo{background:#fff;overflow:hidden;box-shadow:0 2px 8px color-mix(in oklch,var(--ink) 12%,transparent)}.brand-mark--logo img{width:100%;height:100%;object-fit:cover;display:block}.brand-name{font-weight:750;font-size:16px;letter-spacing:-.02em;white-space:nowrap}.brand-sub{font-size:10.5px;color:var(--ink-4);font-weight:600;letter-spacing:.04em;text-transform:uppercase;white-space:nowrap}.nav{padding:8px 12px;flex:1;overflow-y:auto;overflow-x:hidden}.nav-label{font-size:10.5px;font-weight:700;color:var(--ink-4);letter-spacing:.08em;text-transform:uppercase;padding:14px 12px 7px;white-space:nowrap}.collapsed .nav-label{opacity:0;height:8px;padding:4px 0}.nav-item{display:flex;align-items:center;gap:12px;padding:9px 12px;border-radius:var(--r-sm);color:var(--ink-2);font-weight:550;font-size:13.5px;cursor:pointer;white-space:nowrap;position:relative;transition:background .12s,color .12s;margin:1px 0;border:none;background:none;width:100%;text-align:left;font-family:inherit}.nav-item svg{width:19px;height:19px;flex:0 0 19px}.nav-item:hover{background:var(--line-2);color:var(--ink)}.nav-item.active{background:var(--accent-soft);color:var(--accent-ink);font-weight:650}[data-theme=dark] .nav-item.active{color:color-mix(in oklch,var(--accent) 70%,white)}.nav-item .nav-badge{margin-left:auto;font-size:11px;font-weight:700;background:var(--accent);color:#fff;border-radius:99px;padding:1px 7px;min-width:18px;text-align:center}.collapsed .nav-item{justify-content:center;padding:11px}.collapsed .nav-item .nav-txt,.collapsed .nav-item .nav-badge{display:none}.sidebar-foot{border-top:1px solid var(--line);padding:10px 12px}.topbar{height:64px;flex:0 0 64px;background:color-mix(in oklch,var(--surface) 86%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-bottom:1px solid var(--line);display:flex;align-items:center;gap:16px;padding:0 28px;z-index:20}.icon-btn{width:36px;height:36px;border-radius:9px;border:1px solid transparent;background:none;color:var(--ink-2);display:grid;place-items:center;cursor:pointer;transition:background .12s,border-color .12s;position:relative;flex:0 0 auto}.icon-btn:hover{background:var(--line-2);color:var(--ink)}.icon-btn svg{width:19px;height:19px}.icon-btn .dot{position:absolute;top:7px;right:8px;width:7px;height:7px;border-radius:99px;background:var(--danger);border:2px solid var(--surface)}.search{flex:1;max-width:420px;position:relative}.search input{width:100%;height:40px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);padding:0 14px 0 40px;font-family:inherit;font-size:13.5px;color:var(--ink);transition:border-color .12s,box-shadow .12s,background .12s}.search input::placeholder{color:var(--ink-4)}.search input:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft)}.search svg{position:absolute;left:13px;top:50%;transform:translateY(-50%);width:17px;height:17px;color:var(--ink-4);pointer-events:none}.search kbd{position:absolute;right:10px;top:50%;transform:translateY(-50%);font-size:11px;font-family:inherit;color:var(--ink-4);border:1px solid var(--line);border-radius:5px;padding:1px 6px;font-weight:600}.avatar{border-radius:50%;display:grid;place-items:center;font-weight:700;color:#fff;flex:0 0 auto;-webkit-user-select:none;user-select:none;letter-spacing:-.02em;overflow:hidden}.page-head{display:flex;align-items:flex-end;justify-content:space-between;gap:18px;margin-bottom:22px;flex-wrap:wrap}.page-title{font-size:25px;font-weight:760;letter-spacing:-.025em;margin:0}.page-sub{color:var(--ink-3);font-size:13.5px;margin:4px 0 0}.head-actions{display:flex;gap:9px;align-items:center}.org-layout{display:grid;grid-template-columns:220px 1fr;gap:var(--gap);align-items:start}@media(max-width:900px){.org-layout{grid-template-columns:1fr}}.org-nav{display:flex;flex-direction:column;gap:4px;padding:10px!important;position:sticky;top:12px}.settings-perm-grid{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:var(--gap)}@media(max-width:900px){.settings-perm-grid{grid-template-columns:1fr}}.system-access-toggle{display:flex;align-items:flex-start;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:var(--r-lg);background:var(--surface-2);margin-bottom:18px}.org-nav-link{display:flex;align-items:center;gap:10px;padding:10px 12px;border-radius:8px;border:1px solid transparent;font-size:13.5px;font-weight:600;color:var(--ink-2);text-decoration:none;outline:none;transition:background .12s,color .12s}.org-nav-link:hover{background:var(--line-2);color:var(--ink)}.org-nav-link.active{background:var(--accent-soft);color:var(--accent-ink);border-color:color-mix(in oklch,var(--accent) 22%,transparent)}.org-nav-link:focus-visible{box-shadow:0 0 0 3px var(--accent-soft)}[data-theme=dark] .org-nav-link.active{color:color-mix(in oklch,var(--accent) 75%,white)}.section-tabs{display:flex;flex-wrap:wrap;gap:6px;padding:6px;margin-bottom:var(--gap)}.section-tab{display:inline-flex;align-items:center;gap:8px;padding:10px 16px;border-radius:8px;border:1px solid transparent;font-size:13.5px;font-weight:600;color:var(--ink-2);text-decoration:none;outline:none;transition:background .12s,color .12s,border-color .12s;white-space:nowrap}.section-tab:hover{background:var(--line-2);color:var(--ink)}.section-tab.active{background:var(--accent-soft);color:var(--accent-ink);border-color:color-mix(in oklch,var(--accent) 28%,var(--line))}.section-tab:focus-visible{box-shadow:0 0 0 3px var(--accent-soft)}[data-theme=dark] .section-tab.active{color:color-mix(in oklch,var(--accent) 75%,white)}.btn{display:inline-flex;align-items:center;gap:8px;height:38px;padding:0 15px;border-radius:9px;font-family:inherit;font-size:13.5px;font-weight:600;cursor:pointer;border:1px solid var(--line);background:var(--surface);color:var(--ink);transition:background .12s,border-color .12s,box-shadow .12s,transform .06s;white-space:nowrap}.btn svg{width:17px;height:17px}.btn:hover{background:var(--line-2)}.btn:active{transform:translateY(.5px)}.btn.primary{background:var(--accent);border-color:var(--accent);color:#fff;box-shadow:0 2px 8px color-mix(in oklch,var(--accent) 35%,transparent)}.btn.primary:hover{background:var(--accent-ink)}.btn.ghost{background:none;border-color:transparent}.btn.ghost:hover{background:var(--line-2)}.btn.sm{height:32px;padding:0 11px;font-size:12.5px}.btn.icon{padding:0;width:38px;justify-content:center}.card{background:var(--surface);border:1px solid var(--line);border-radius:var(--r-lg);box-shadow:var(--shadow-sm)}.card-pad{padding:var(--pad)}.card-head{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:16px var(--pad);border-bottom:1px solid var(--line)}.card-title{font-weight:700;font-size:14.5px;letter-spacing:-.01em}.card-link{color:var(--accent);font-weight:600;font-size:12.5px;cursor:pointer;background:none;border:none;font-family:inherit}.card-link:hover{text-decoration:underline}.badge{display:inline-flex;align-items:center;gap:5px;height:23px;padding:0 9px;border-radius:99px;font-size:11.5px;font-weight:650;letter-spacing:-.01em;white-space:nowrap}.badge .bdot{width:6px;height:6px;border-radius:99px;background:currentColor}.badge.ok{background:var(--ok-soft);color:var(--ok)}.badge.warn{background:var(--warn-soft);color:var(--warn)}.badge.danger{background:var(--danger-soft);color:var(--danger)}.badge.info{background:var(--info-soft);color:var(--info)}.badge.violet{background:var(--violet-soft);color:var(--violet)}.badge.neutral{background:var(--line-2);color:var(--ink-3)}.chip{display:inline-flex;align-items:center;gap:6px;height:30px;padding:0 12px;border-radius:8px;border:1px solid var(--line);background:var(--surface);font-size:12.5px;font-weight:600;color:var(--ink-2);cursor:pointer;transition:background .12s,border-color .12s,color .12s;white-space:nowrap;font-family:inherit}.chip:hover{background:var(--line-2)}.chip.active{background:var(--accent-soft);border-color:color-mix(in oklch,var(--accent) 35%,var(--line));color:var(--accent-ink)}[data-theme=dark] .chip.active{color:color-mix(in oklch,var(--accent) 75%,white)}.chip-row{display:flex;gap:8px;flex-wrap:wrap;align-items:center}.stat-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:var(--gap)}.stat{padding:var(--pad);position:relative;overflow:hidden}.stat-top{display:flex;align-items:center;gap:10px;margin-bottom:14px}.stat-ic{width:38px;height:38px;border-radius:10px;display:grid;place-items:center;flex:0 0 38px}.stat-ic svg{width:20px;height:20px}.stat-label{font-size:12.5px;color:var(--ink-3);font-weight:600}.stat-val{font-size:30px;font-weight:770;letter-spacing:-.03em;line-height:1}.stat-val .unit{font-size:15px;color:var(--ink-3);font-weight:600;margin-left:3px}.stat-delta{display:inline-flex;align-items:center;gap:4px;font-size:12px;font-weight:650;margin-top:10px}.stat-delta.up{color:var(--ok)}.stat-delta.down{color:var(--danger)}.stat-delta .muted{color:var(--ink-4);font-weight:500}.tbl{width:100%;border-collapse:collapse}.tbl thead th{text-align:left;font-size:11px;font-weight:700;color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em;padding:11px var(--pad);border-bottom:1px solid var(--line);white-space:nowrap;background:var(--surface-2);position:sticky;top:0;z-index:1}.tbl tbody td{padding:0 var(--pad);height:var(--row-h);border-bottom:1px solid var(--line-2);font-size:13.5px;vertical-align:middle}.tbl tbody tr{transition:background .1s;cursor:pointer}.tbl tbody tr:hover{background:var(--surface-2)}.tbl tbody tr:last-child td{border-bottom:none}.tbl th:first-child,.tbl td:first-child{min-width:210px}.att-tbl .status-badge-wrap--tip .badge{cursor:help}.cell-name{display:flex;align-items:center;gap:11px;width:100%;min-width:0}.cell-name>div{min-width:0}.cell-name .nm{font-weight:650;color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.cell-name .sub{font-size:11.5px;color:var(--ink-4);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.t-right{text-align:right}.t-num{font-variant-numeric:tabular-nums}.bar{height:7px;border-radius:99px;background:var(--line);overflow:hidden}.bar>span{display:block;height:100%;border-radius:99px;background:var(--accent)}.scrim{position:fixed;inset:0;width:100vw;height:100vh;height:100dvh;margin:0;padding:0;border:none;background:#14182073;backdrop-filter:blur(2px);-webkit-backdrop-filter:blur(2px);z-index:200}.drawer{position:fixed;top:0;right:0;height:100vh;height:100dvh;width:480px;max-width:94vw;background:var(--canvas);z-index:210;box-shadow:var(--shadow-lg);display:flex;flex-direction:column;animation:slideIn .26s cubic-bezier(.32,.72,0,1)}@keyframes slideIn{0%{transform:translate(34px)}to{transform:none}}@keyframes fade{0%{opacity:0}to{opacity:1}}.drawer-head{padding:20px 24px;display:flex;align-items:flex-start;gap:14px}.drawer-body{flex:1;overflow-y:auto;padding:0 24px 32px}.row{display:flex;align-items:center}.between{justify-content:space-between}.muted{color:var(--ink-3)}.divider{height:1px;background:var(--line);border:none;margin:0}.kv{display:grid;grid-template-columns:116px 1fr;gap:10px 14px;font-size:13.5px}.kv dt{color:var(--ink-3)}.kv dd{margin:0;font-weight:600}.empty{text-align:center;padding:48px 20px;color:var(--ink-4)}.seg{display:inline-flex;background:var(--line-2);border-radius:9px;padding:3px;gap:2px}.seg button{border:none;background:none;font-family:inherit;font-size:12.5px;font-weight:600;color:var(--ink-3);padding:6px 13px;border-radius:6px;cursor:pointer;transition:all .12s}.seg button.active{background:var(--surface);color:var(--ink);box-shadow:var(--shadow-sm)}.fade-in{opacity:1;will-change:transform}@media(prefers-reduced-motion:no-preference){.fade-in{animation:fadeUp .34s cubic-bezier(.32,.72,0,1) both}}@keyframes fadeUp{0%{transform:translateY(8px)}to{transform:none}}.tag-dept{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;font-weight:600;color:var(--ink-2)}.tag-dept .dept-dot{width:8px;height:8px;border-radius:3px}.modal-wrap{position:fixed;inset:0;z-index:210;display:grid;place-items:center;padding:24px}.modal{position:relative;width:100%;max-width:560px;max-height:90vh;background:var(--surface);border-radius:var(--r-xl);box-shadow:var(--shadow-lg);display:flex;flex-direction:column;overflow:hidden;animation:modalIn .26s cubic-bezier(.32,.72,0,1)}.modal.wide{max-width:680px}@keyframes modalIn{0%{transform:translateY(14px) scale(.985)}to{transform:none}}.modal-head{padding:22px 26px 16px;display:flex;align-items:flex-start;gap:14px;border-bottom:1px solid var(--line)}.modal-head .m-ic{width:42px;height:42px;border-radius:12px;background:var(--accent-soft);color:var(--accent);display:grid;place-items:center;flex:0 0 42px}[data-theme=dark] .modal-head .m-ic{color:color-mix(in oklch,var(--accent) 72%,white)}.modal-title{font-size:18px;font-weight:750;letter-spacing:-.02em}.modal-sub{font-size:13px;color:var(--ink-3);margin-top:2px}.modal-body{padding:22px 26px;overflow-y:auto}.modal-foot{padding:16px 26px;border-top:1px solid var(--line);display:flex;gap:10px;justify-content:flex-end;background:var(--surface-2)}.modal-foot .spacer{flex:1}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px 18px}.field{display:flex;flex-direction:column;gap:7px;min-width:0}.field.full{grid-column:1 / -1}.field>label{font-size:12.5px;font-weight:650;color:var(--ink-2);display:flex;align-items:center;gap:5px}.field>label .req{color:var(--danger)}.field .hint{font-size:11.5px;color:var(--ink-4)}.field .err{font-size:11.5px;color:var(--danger);font-weight:600}.inp,.sel,.ta{width:100%;height:42px;border-radius:10px;border:1px solid var(--line);background:var(--surface-2);padding:0 13px;font-family:inherit;font-size:14px;color:var(--ink);transition:border-color .12s,box-shadow .12s,background .12s}.ta{height:auto;min-height:80px;padding:11px 13px;resize:vertical;line-height:1.5}.inp::placeholder,.ta::placeholder{color:var(--ink-4)}.inp:focus,.sel:focus,.ta:focus{outline:none;border-color:var(--accent);background:var(--surface);box-shadow:0 0 0 3px var(--accent-soft)}.inp.invalid,.sel.invalid{border-color:var(--danger)}.inp-pre{position:relative}.inp-pre .pre{position:absolute;left:13px;top:50%;transform:translateY(-50%);font-size:13px;font-weight:650;color:var(--ink-4);pointer-events:none}.inp-pre .inp{padding-left:44px}.sel{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%239aa1ae' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 13px center;padding-right:38px;cursor:pointer}.segmented{display:flex;gap:7px;flex-wrap:wrap}.seg-opt{flex:1;min-width:0;height:40px;border-radius:9px;border:1px solid var(--line);background:var(--surface-2);font-family:inherit;font-size:13px;font-weight:600;color:var(--ink-2);cursor:pointer;transition:all .12s;display:flex;align-items:center;justify-content:center;gap:6px;white-space:nowrap;padding:0 10px}.seg-opt:hover{background:var(--line-2)}.seg-opt.on{background:var(--accent-soft);border-color:color-mix(in oklch,var(--accent) 40%,var(--line));color:var(--accent-ink)}[data-theme=dark] .seg-opt.on{color:color-mix(in oklch,var(--accent) 75%,white)}.swatches{display:flex;gap:9px;flex-wrap:wrap}.swatch{width:30px;height:30px;border-radius:9px;cursor:pointer;position:relative;border:2px solid transparent;transition:transform .1s}.swatch:hover{transform:scale(1.08)}.swatch.on{box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--ink)}.swatch{display:grid;place-items:center;padding:0}.segmented--triple .seg-opt{font-size:12px;padding:0 8px}.field-hint{display:block;font-size:12px;color:var(--ink-4);margin-top:6px;line-height:1.4}.field-label-row{display:flex;align-items:baseline;justify-content:space-between;gap:8px;flex-wrap:wrap;font-size:12.5px;font-weight:650;color:var(--ink-2)}.field-label-row .hint{font-weight:500;white-space:nowrap}.attendance-page .att-live{color:var(--ink-4);font-weight:500}.att-head-actions{flex-wrap:wrap;align-items:center}.att-period-bar{display:inline-flex;align-items:center;gap:10px;flex-wrap:nowrap;max-width:100%}.att-period-bar .segmented{flex-wrap:nowrap}.att-period{background:var(--surface-2);border:1px solid var(--line);border-radius:10px;padding:4px;flex-shrink:0}.att-period .seg-opt{flex:0 0 auto;min-width:52px;height:32px;border:none;background:transparent;box-shadow:none;font-size:12px;padding:0 10px}.att-period .seg-opt.on{background:var(--surface);box-shadow:var(--shadow-sm);border:1px solid var(--line)}.att-range-fields{display:inline-flex;align-items:center;gap:6px;flex-wrap:nowrap;flex-shrink:0}.att-range-inp{width:118px;min-width:118px;max-width:118px;height:32px;padding:0 6px 0 8px;font-size:12.5px;box-sizing:border-box}.att-range-fields__sep{font-size:12px;font-weight:600;color:var(--ink-3);flex-shrink:0;line-height:1}@media(max-width:720px){.att-period-bar{flex-wrap:wrap;row-gap:8px}}.shift-page{display:flex;flex-direction:column;gap:var(--gap)}.shift-page-head{align-items:flex-start;gap:12px;flex-wrap:wrap}.shift-page-title{margin:0;font-size:22px;font-weight:780;letter-spacing:-.03em;color:var(--ink)}.shift-page-sub{margin:4px 0 0;font-size:13.5px}.shift-cards-scroll{display:flex;gap:12px;overflow-x:auto;padding-bottom:4px;scrollbar-width:thin}.shift-card{position:relative;flex:0 0 228px;display:flex;flex-direction:column;text-align:left;padding:0;border:1px solid var(--line);background:var(--surface);overflow:hidden;cursor:default;transition:box-shadow .15s,border-color .15s}.shift-card:not(.shift-card--new):before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--shift-accent, var(--accent));border-radius:var(--r-lg) 0 0 var(--r-lg)}.shift-card--clickable{cursor:pointer}.shift-card--clickable:hover{border-color:color-mix(in oklch,var(--shift-accent, var(--accent)) 28%,var(--line));box-shadow:var(--shadow)}.shift-card__body{flex:1;padding:16px 18px 14px 22px}.shift-card__name{font-size:15px;font-weight:740;letter-spacing:-.02em;color:var(--ink);line-height:1.2;margin-bottom:10px}.shift-card__time{display:flex;align-items:baseline;flex-wrap:wrap;gap:2px 4px;font-size:21px;font-weight:780;letter-spacing:-.03em;color:var(--ink);line-height:1.15;margin-bottom:6px}.shift-card__next{font-size:11px;font-weight:650;color:var(--ink-3);letter-spacing:0;margin-left:1px;top:-.35em}.shift-card__meta{font-size:12.5px;line-height:1.35;color:var(--ink-3)}.shift-card__divider{height:1px;margin:0 18px 0 22px;background:var(--line)}.shift-card__foot{display:flex;align-items:center;gap:8px;padding:12px 18px 14px 22px;font-size:12.5px;color:var(--ink-3);font-weight:500}.shift-card__foot-dot{width:7px;height:7px;border-radius:50%;background:var(--shift-accent, var(--accent));flex-shrink:0}.shift-color-pick{display:flex;flex-wrap:wrap;gap:8px}.shift-color-pick__swatch{width:32px;height:32px;border-radius:50%;border:2px solid transparent;cursor:pointer;padding:0;box-shadow:inset 0 0 0 1px #1c22301f;transition:transform .12s,box-shadow .12s}.shift-color-pick__swatch:hover{transform:scale(1.06)}.shift-color-pick__swatch.on{border-color:var(--ink);box-shadow:0 0 0 2px var(--surface),0 0 0 4px var(--ink)}.shift-card--new{flex:0 0 200px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:10px;min-height:148px;border:1.5px dashed var(--line);background:var(--surface);color:var(--ink-3);font-size:13.5px;font-weight:600;box-shadow:none}.shift-card--new:before{display:none}.shift-card__new-icon{display:flex;align-items:center;justify-content:center;width:44px;height:44px;border-radius:12px;background:var(--surface-2);color:var(--ink-3);border:1px solid var(--line)}.shift-card--new:hover{border-color:color-mix(in oklch,var(--accent) 40%,var(--line));color:var(--ink-2);background:var(--surface);box-shadow:var(--shadow-sm)}.shift-card--new:hover .shift-card__new-icon{color:var(--accent);border-color:color-mix(in oklch,var(--accent) 25%,var(--line));background:var(--accent-softer)}.shift-roster{overflow:hidden;padding:0}.shift-roster__head{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap;padding:16px 18px 12px;border-bottom:1px solid var(--line-2)}.shift-roster__title{margin:0;font-size:15px;font-weight:720;letter-spacing:-.01em}.shift-roster__nav{display:flex;align-items:center;gap:6px}.shift-roster__range{font-size:13px;font-weight:650;color:var(--ink-2);min-width:160px;text-align:center}.shift-roster__filters{padding:0 18px 14px}.shift-roster__grid-wrap{overflow:auto;max-height:min(62vh,640px)}.shift-roster__grid{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}.shift-roster__grid th,.shift-roster__grid td{border-bottom:1px solid var(--line-2);vertical-align:middle}.shift-roster__emp-col{position:sticky;left:0;z-index:2;background:var(--surface);min-width:200px;padding:10px 14px;text-align:left;box-shadow:2px 0 6px #1c22300a}.shift-roster__emp-count{font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3)}.shift-roster__day-col{min-width:88px;padding:10px 8px;text-align:center;background:var(--surface)}.shift-roster__day-col--off{background:color-mix(in oklch,var(--warn-soft) 55%,var(--surface))}.shift-roster__dow{display:block;font-size:10px;font-weight:700;letter-spacing:.06em;color:var(--ink-3)}.shift-roster__dom{display:block;font-size:15px;font-weight:720;color:var(--ink);margin-top:2px}.shift-roster__emp{position:sticky;left:0;z-index:1;background:var(--surface);padding:10px 14px;box-shadow:2px 0 6px #1c22300a}.shift-roster__cell{padding:8px;text-align:center;background:var(--surface)}.shift-roster__cell--off{background:color-mix(in oklch,var(--warn-soft) 40%,var(--surface))}.shift-roster__block{display:flex;flex-direction:column;align-items:flex-start;gap:2px;padding:8px 10px;border-radius:8px;background:color-mix(in oklch,var(--block-color, var(--accent)) 14%,white);border-left:3px solid var(--block-color, var(--accent));text-align:left;min-height:44px}.shift-roster__block-name{font-size:12px;font-weight:700;color:var(--ink);line-height:1.2}.shift-roster__block-time{font-size:11px;color:var(--ink-3)}.assign-shift-page{display:flex;flex-direction:column;gap:var(--gap)}.assign-shift-page__head{align-items:flex-start}.assign-shift-page__back{display:inline-flex;align-items:center;gap:4px;font-size:13px;font-weight:600;color:var(--ink-3);text-decoration:none;margin-bottom:8px}.assign-shift-page__back:hover{color:var(--accent)}.assign-shift-page__title{margin:0;font-size:22px;font-weight:780;letter-spacing:-.03em}.assign-shift-page__sub{margin:4px 0 0;font-size:13.5px}.assign-shift-page__grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);align-items:start}@media(max-width:900px){.assign-shift-page__grid{grid-template-columns:1fr}}.assign-shift-page__col-left{display:flex;flex-direction:column;gap:var(--gap)}.assign-shift-box{padding:18px 20px;overflow:hidden}.assign-shift-box--employees{display:flex;flex-direction:column;min-height:480px;max-height:calc(100vh - 280px)}.assign-shift-page__foot{padding:0;overflow:hidden}.assign-shift-page__foot .assign-shift__bar{border-top:none;background:var(--surface)}.assign-shift__section-title{margin:0 0 12px;font-size:13px;font-weight:720;display:flex;align-items:center;gap:8px}.assign-shift__step{display:inline-grid;place-items:center;width:22px;height:22px;border-radius:50%;background:var(--accent-softer);color:var(--accent);font-size:11px;font-weight:800}.assign-shift__shift-grid{display:grid;grid-template-columns:1fr 1fr;gap:10px}.assign-shift__shift-opt{display:flex;flex-direction:column;gap:4px;padding:12px 12px 10px;border:1px solid var(--line);border-radius:var(--r);cursor:pointer;transition:border-color .12s,box-shadow .12s;position:relative}.assign-shift__shift-opt input{position:absolute;opacity:0;pointer-events:none}.assign-shift__shift-opt--on{border-color:var(--shift-accent, var(--accent));box-shadow:0 0 0 1px color-mix(in oklch,var(--shift-accent, var(--accent)) 25%,transparent)}.assign-shift__shift-radio{width:16px;height:16px;border-radius:50%;border:2px solid var(--line);margin-bottom:2px}.assign-shift__shift-opt--on .assign-shift__shift-radio{border-color:var(--shift-accent, var(--accent));background:radial-gradient(circle at center,var(--shift-accent, var(--accent)) 0 35%,transparent 40%)}.assign-shift__shift-name{font-size:14px;font-weight:700}.assign-shift__shift-time{font-size:12px}.assign-shift__dates{gap:10px;margin-bottom:12px}.assign-shift__date-inp{height:36px;font-size:13px;width:100%;box-sizing:border-box}.assign-shift__date-summary{margin:10px 0 0;font-size:12.5px;line-height:1.45}.assign-shift__emp-head{margin-bottom:12px;align-items:center}.assign-shift__badge{font-size:11.5px;font-weight:700;padding:4px 10px;border-radius:999px;background:var(--ok-soft);color:var(--ok)}.assign-shift__filters{display:grid;grid-template-columns:1fr 1fr;gap:12px;margin-bottom:12px}.assign-shift__filter-field{min-width:0}.assign-shift__filter-field:first-child{grid-column:1 / -1}.assign-shift__filter-sel{width:100%;height:36px;font-size:13px}.assign-shift__search{position:relative}.assign-shift__search svg{position:absolute;left:10px;top:50%;transform:translateY(-50%);color:var(--ink-4);pointer-events:none}.assign-shift__search .inp{padding-left:34px;height:36px;width:100%;box-sizing:border-box}.assign-shift__select-all{display:flex;align-items:center;gap:10px;padding:8px 0 10px;font-size:13px;font-weight:650;cursor:pointer;border-bottom:1px solid var(--line-2)}.assign-shift__emp-list{flex:1;overflow-y:auto;min-height:240px}.assign-shift-box--employees .assign-shift__emp-list{max-height:none}.assign-shift__emp-row{display:flex;align-items:center;gap:12px;padding:10px 4px;border-bottom:1px solid var(--line-2);cursor:pointer}.assign-shift__emp-row:hover{background:var(--surface-2)}.assign-shift__emp-meta{flex:1;min-width:0}.assign-shift__emp-meta .nm{font-size:13.5px;font-weight:650}.assign-shift__emp-meta .sub{font-size:12px;display:block;margin-top:2px}.assign-shift__bar{display:flex;align-items:center;gap:16px;flex-wrap:wrap;padding:16px 20px}.assign-shift__bar-hint{flex:1;margin:0;font-size:13.5px;color:var(--ink-3);display:flex;align-items:center;gap:8px}.assign-shift__bar-hint-mark{color:var(--accent);font-weight:800}.assign-shift__bar-stat{flex-shrink:0}.assign-shift__bar-n{display:block;font-size:22px;font-weight:800;letter-spacing:-.02em;color:var(--ink);line-height:1}.assign-shift__bar-l{font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3)}.assign-shift__bar-mid{flex:1;min-width:200px}.assign-shift__bar-summary{margin:0;font-size:13px;font-weight:650;color:var(--ink-2)}.assign-shift__bar-warn{margin:4px 0 0;font-size:12.5px;color:var(--warn);font-weight:600}.assign-shift__submit{flex-shrink:0;min-width:160px;height:44px;font-size:14px}.payroll-run-row{cursor:pointer}.payroll-run-row:hover td{background:var(--surface-2)}.payroll-preview-summary__grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.payroll-run-page__back{display:inline-flex;align-items:center;gap:6px;font-size:13px;font-weight:600;color:var(--ink-3);text-decoration:none;margin-bottom:14px}.payroll-run-page__back:hover{color:var(--accent)}.payroll-run-head__title{margin:0;font-size:22px;font-weight:780;letter-spacing:-.03em}.payroll-run-head__sub{margin:6px 0 0;font-size:13.5px}.payroll-run-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:var(--gap);margin-bottom:var(--gap)}@media(max-width:720px){.payroll-run-stats,.payroll-preview-summary__grid{grid-template-columns:1fr}}.payroll-run-stat__val{font-size:22px;font-weight:740;margin-top:6px;letter-spacing:-.02em}.payroll-line-row{cursor:pointer}.payroll-line-row:hover td{background:var(--surface-2)}.payroll-line-detail td{background:var(--surface-2);padding:0 16px 12px!important;border-bottom:1px solid var(--line)}.payroll-breakdown{display:grid;gap:6px;padding:10px 12px;border-radius:8px;background:var(--surface);border:1px solid var(--line)}.payroll-breakdown__row{display:flex;justify-content:space-between;gap:12px;font-size:12.5px;color:var(--ink-2)}.payroll-dash__toolbar{margin-bottom:var(--gap)}.payroll-dash__period{min-width:220px}.payroll-dash__stats{margin-bottom:var(--gap)}@media(max-width:1000px){.stat-grid.payroll-dash__stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:520px){.stat-grid.payroll-dash__stats{grid-template-columns:1fr}}.payroll-dash__main{display:grid;grid-template-columns:3fr 1fr;gap:var(--gap);align-items:start}@media(max-width:960px){.payroll-dash__main{grid-template-columns:1fr}}.payroll-register{overflow:hidden;padding:0}.payroll-register__head{display:flex;flex-wrap:wrap;align-items:center;justify-content:space-between;gap:12px;padding:16px var(--pad);border-bottom:1px solid var(--line)}.payroll-register__title{margin:0;font-size:15px;font-weight:740;letter-spacing:-.02em}.payroll-register__filters{flex:1;justify-content:flex-end;min-width:0}.payroll-register__table-wrap{overflow:visible}.payroll-register__row{cursor:pointer}.payroll-register__row--open td{background:var(--surface-2)}.payroll-register__chev{margin-left:auto;flex-shrink:0;color:var(--ink-4);transition:transform .15s}.payroll-register__detail td{padding:0 16px 16px!important;background:var(--surface-2);border-bottom:1px solid var(--line);cursor:default}.payroll-breakdown-panels{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-top:13px}@media(max-width:720px){.payroll-breakdown-panels{grid-template-columns:1fr}}.payroll-mini-table{overflow:hidden;border:1px solid var(--line);box-shadow:none}.payroll-mini-table__grid{width:100%;border-collapse:collapse;font-size:13px}.payroll-mini-table__grid thead th{text-align:left;font-size:11px;font-weight:700;letter-spacing:.04em;text-transform:uppercase;color:var(--ink-3);padding:10px 14px;background:color-mix(in oklch,var(--accent) 8%,var(--surface-2));border-bottom:1px solid var(--line)}.payroll-mini-table__grid .t-right,.payroll-mini-table__grid thead th.t-right{text-align:right}.payroll-mini-table__grid tbody td{border-bottom:1px solid var(--line-2);color:var(--ink-2);height:25px;padding:6px!important}.payroll-mini-table__grid tbody tr:last-child td{border-bottom:none}.payroll-mini-table__grid tfoot td{padding:11px 14px!important;font-weight:700;color:var(--ink);background:color-mix(in oklch,var(--accent) 8%,var(--surface-2));border-top:1px solid var(--line);height:25px}.payroll-mini-table__grid tfoot td.t-right{text-align:right}.payroll-mini-table__deduct,.payroll-register__deduct{color:var(--danger);font-weight:600}.payroll-register__net{font-weight:700;color:var(--ink)}.payroll-payslip-btn{display:inline-flex;align-items:center;gap:6px;padding:6px 10px;border:1px solid var(--line);border-radius:8px;background:var(--surface);font-family:inherit;font-size:12px;font-weight:600;color:var(--ink-2);cursor:pointer}.payroll-payslip-btn:hover{border-color:var(--accent);color:var(--accent);background:var(--accent-softer)}.payroll-dept-cost{padding:18px 20px}.payroll-dept-cost__title{margin:0 0 16px;font-size:15px;font-weight:740;letter-spacing:-.02em}.payroll-dept-cost__list{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:14px}.payroll-dept-cost__row{display:grid;grid-template-columns:10px 1fr auto;grid-template-areas:"dot name val" "dot bar bar";align-items:center;gap:4px 8px;font-size:13px}.payroll-dept-cost__dot{grid-area:dot;align-self:center}.payroll-dept-cost__name{grid-area:name;min-width:0}.payroll-dept-cost__val{grid-area:val}.payroll-dept-cost__bar-wrap{grid-area:bar}.payroll-dept-cost__dot{width:9px;height:9px;border-radius:50%;flex-shrink:0}.payroll-dept-cost__name{font-weight:600;color:var(--ink-2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.payroll-dept-cost__bar-wrap{height:8px;border-radius:99px;background:var(--line);overflow:hidden}.payroll-dept-cost__bar{height:100%;border-radius:99px;min-width:4px;transition:width .2s ease}.payroll-dept-cost__val{text-align:right;font-size:12.5px;font-weight:650;color:var(--ink-3)}.payroll-empty{text-align:center;padding:56px 24px!important}.payslip-scrim{align-items:flex-start;padding:24px 16px;overflow-y:auto}.payslip-modal-wrap{width:100%;max-width:900px;margin:0 auto}.payslip-sheet{padding:28px 32px 24px;border:1px solid var(--line);box-shadow:var(--shadow-lg)}.payslip-sheet__head{display:flex;justify-content:space-between;align-items:flex-start;gap:20px;flex-wrap:wrap}.payslip-sheet__brand{display:flex;gap:14px;align-items:flex-start;max-width:55%}.payslip-sheet__logo{width:64px;height:64px;border-radius:30px;background:var(--accent);display:grid;place-items:center;overflow:hidden;flex-shrink:0;box-shadow:0 2px 8px color-mix(in oklch,var(--accent) 35%,transparent)}.payslip-sheet__logo img{width:100%;height:100%;object-fit:cover}.payslip-sheet__org-name{font-size:17px;font-weight:780;letter-spacing:-.02em;color:var(--ink);line-height:1.2}.payslip-sheet__org-meta{margin:4px 0 0;font-size:12px;color:var(--ink-3);line-height:1.4}.payslip-sheet__title-block{text-align:right}.payslip-sheet__title{margin:0;font-size:26px;font-weight:800;letter-spacing:-.03em;color:var(--accent);line-height:1.1}.payslip-sheet__period{margin:4px 0 10px;font-size:14px;font-weight:650;color:var(--ink-2)}.payslip-sheet__badge{display:inline-block;padding:4px 10px;border-radius:99px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);background:var(--surface-2);border:1px solid var(--line)}.payslip-sheet__rule{height:4px;margin:20px 0 22px;border-radius:99px;background:var(--accent)}.payslip-meta{display:grid;grid-template-columns:repeat(3,1fr);gap:20px 28px;margin-bottom:22px}@media(max-width:760px){.payslip-meta{grid-template-columns:1fr}}.payslip-meta__item{margin-bottom:10px}.payslip-meta__item:last-child{margin-bottom:0}.payslip-meta__label{display:block;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-4);margin-bottom:3px}.payslip-meta__val{display:block;font-size:13px;font-weight:650;color:var(--ink);line-height:1.35}.payslip-sheet__tables{display:grid;grid-template-columns:1fr 1fr;gap:16px;margin-bottom:18px}@media(max-width:640px){.payslip-sheet__tables{grid-template-columns:1fr}}.payslip-sheet__table-card{border:1px solid var(--line);border-radius:var(--r-lg);overflow:hidden}.payslip-sheet__tbl{width:100%;border-collapse:collapse;font-size:12.5px}.payslip-sheet__tbl thead th{text-align:left;font-size:10px;font-weight:700;letter-spacing:.05em;text-transform:uppercase;color:var(--ink-3);padding:8px 14px;background:color-mix(in oklch,var(--accent) 8%,var(--surface-2));border-bottom:1px solid var(--line)}.payslip-sheet__tbl thead th.t-right,.payslip-sheet__tbl tbody td.t-right,.payslip-sheet__tbl tfoot td.t-right{text-align:right}.payslip-sheet__tbl tbody td{padding:7px 14px;border-bottom:1px solid var(--line-2);color:var(--ink-2)}.payslip-sheet__tbl tbody tr:last-child td{border-bottom:none}.payslip-sheet__tbl tfoot td{padding:9px 14px;font-weight:700;color:var(--ink);background:color-mix(in oklch,var(--accent) 8%,var(--surface-2));border-top:1px solid var(--line)}.payslip-sheet__deduct{color:var(--danger);font-weight:600}.payslip-sheet__net{display:flex;justify-content:space-between;align-items:center;gap:20px;flex-wrap:wrap;padding:20px 22px;border-radius:var(--r-lg);background:var(--accent);color:#fff;margin-bottom:14px}.payslip-sheet__net-label{font-size:11px;font-weight:700;letter-spacing:.06em;text-transform:uppercase;opacity:.92;margin-bottom:6px}.payslip-sheet__net-words{margin:0;font-size:13px;font-weight:500;line-height:1.45;max-width:420px;opacity:.95}.payslip-sheet__net-amount{display:flex;align-items:baseline;gap:8px;flex-shrink:0}.payslip-sheet__net-currency{font-size:15px;font-weight:700;opacity:.9}.payslip-sheet__net-value{font-size:36px;font-weight:800;letter-spacing:-.03em;line-height:1}.payslip-sheet__foot-note{margin:0;font-size:11.5px;text-align:center}@media print{@page{size:A4 portrait;margin:10mm}body{background:#fff!important}body.payslip-printing .app,.payslip-modal-actions{display:none!important}.scrim.payslip-scrim{position:static!important;inset:auto!important;width:auto!important;height:auto!important;min-height:0!important;max-height:none!important;overflow:visible!important;padding:0!important;margin:0!important;background:#fff!important;backdrop-filter:none!important;-webkit-backdrop-filter:none!important;align-items:stretch!important;z-index:auto!important}.payslip-modal-wrap{width:100%!important;max-width:none!important;margin:0!important}.payslip-sheet{position:static!important;width:100%!important;max-width:none!important;margin:0!important;padding:16px 18px!important;box-shadow:none!important;border:none!important;overflow:visible!important;page-break-inside:avoid;-webkit-print-color-adjust:exact;print-color-adjust:exact}.payslip-sheet__head{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;justify-content:space-between!important;align-items:flex-start!important}.payslip-sheet__brand{max-width:58%!important}.payslip-sheet__title-block{text-align:right!important;flex-shrink:0!important}.payslip-meta{display:grid!important;grid-template-columns:repeat(3,1fr)!important;gap:16px 24px!important}.payslip-sheet__tables{display:grid!important;grid-template-columns:1fr 1fr!important;gap:14px!important}.payslip-sheet__table-card{overflow:visible!important;break-inside:avoid}.payslip-sheet__net{display:flex!important;flex-direction:row!important;flex-wrap:nowrap!important;justify-content:space-between!important;background:var(--accent)!important;color:#fff!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.payslip-sheet__rule{background:var(--accent)!important;-webkit-print-color-adjust:exact;print-color-adjust:exact}.payslip-sheet__tbl thead th,.payslip-sheet__tbl tfoot td{-webkit-print-color-adjust:exact;print-color-adjust:exact}}.att-report-widgets{display:grid;grid-template-columns:minmax(280px,360px) 1fr;gap:var(--gap);margin-bottom:var(--gap);align-items:stretch}@media(max-width:900px){.att-report-widgets{grid-template-columns:1fr}.att-summary-card--top{flex-direction:column;gap:16px;min-height:0}}.att-summary-card{padding:22px 20px 18px;display:flex;flex-direction:column;align-items:center;gap:18px}.att-summary-card--top{flex-direction:row;align-items:center;justify-content:center;gap:24px;padding:18px 22px;min-height:148px}.att-summary-card--top .att-summary-stats{max-width:200px}.att-hours-card--top{display:flex;flex-direction:column;min-height:148px}.att-report-bars{flex:1;height:72px;margin-bottom:0;min-height:72px}.att-donut{position:relative;display:grid;place-items:center}.att-donut__label{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.att-donut__pct{font-size:26px;font-weight:780;letter-spacing:-.03em;color:var(--ink);line-height:1}.att-donut__sub{font-size:11.5px;font-weight:600;color:var(--ink-3);margin-top:2px}.att-summary-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;width:100%;text-align:center}.att-stat__n{display:block;font-size:22px;font-weight:780;letter-spacing:-.02em;line-height:1.1}.att-stat__l{display:block;font-size:11.5px;font-weight:600;color:var(--ink-3);margin-top:2px}.att-stat--ok .att-stat__n{color:var(--ok)}.att-stat--info .att-stat__n{color:var(--info)}.att-stat--warn .att-stat__n{color:var(--warn)}.att-hours-card{padding:16px 18px 14px}.att-hours-title{margin:0 0 14px;font-size:14px;font-weight:700;letter-spacing:-.01em}.att-week-bars__chart{display:flex;align-items:flex-end;justify-content:space-between;gap:6px;height:100px;margin-bottom:12px}.att-week-bars__col{flex:1;display:flex;flex-direction:column;align-items:center;gap:6px;min-width:0}.att-week-bars__track{width:100%;max-width:28px;height:80px;display:flex;align-items:flex-end;justify-content:center}.att-week-bars__fill{width:100%;min-height:4px;border-radius:6px 6px 3px 3px;background:var(--accent);transition:height .2s}.att-week-bars__lbl{font-size:11px;font-weight:650;color:var(--ink-4)}.att-week-bars__foot{display:flex;align-items:center;justify-content:space-between;font-size:12.5px;padding-top:10px;border-top:1px solid var(--line-2)}.att-week-bars__foot strong{font-size:14px;font-weight:700;color:var(--ink)}.att-table-card{overflow:hidden;min-width:0}.att-table-toolbar{padding:14px var(--pad);border-bottom:1px solid var(--line)}.att-table-wrap{overflow-x:auto}.att-tbl tbody tr{cursor:default}.att-tbl tbody tr.att-row--click{cursor:pointer}.att-edit-btn{width:32px;height:32px;border-radius:8px;border:none;display:grid;place-items:center;cursor:pointer;color:#fff;background:var(--info);opacity:0;transition:opacity .12s,transform .1s}.att-tbl tbody tr:hover .att-edit-btn{opacity:1}.att-edit-btn:hover{transform:translateY(-1px)}.dash-widget-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--gap);margin-bottom:var(--gap)}@media(max-width:900px){.dash-widget-grid{grid-template-columns:1fr}}.dash-att-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:14px 20px;padding:16px var(--pad) 8px}@media(max-width:520px){.dash-att-metrics{grid-template-columns:1fr}}.dash-att-metric__top{display:flex;align-items:center;justify-content:space-between;gap:8px;margin-bottom:8px;font-size:12.5px;font-weight:600;color:var(--ink-2)}.dash-att-metric__label{display:inline-flex;align-items:center;gap:7px}.dash-att-metric__val{font-size:13px;font-weight:700;color:var(--ink)}.dash-dot{width:8px;height:8px;border-radius:99px;flex-shrink:0}.dash-dot.ok{background:var(--ok)}.dash-dot.info{background:var(--info)}.dash-dot.violet{background:var(--violet)}.dash-dot.neutral{background:var(--ink-4)}.dash-att-bar{height:6px;border-radius:99px;background:var(--line-2);overflow:hidden}.dash-att-bar__fill{height:100%;border-radius:99px;transition:width .25s}.dash-att-bar__fill.ok{background:var(--ok)}.dash-att-bar__fill.info{background:var(--info)}.dash-att-bar__fill.violet{background:var(--violet)}.dash-att-bar__fill.neutral{background:var(--ink-4)}.dash-att-chart{padding:8px var(--pad) 18px;border-top:1px solid var(--line-2);margin-top:8px}.dash-att-chart__head{display:flex;align-items:center;justify-content:space-between;gap:10px;margin-bottom:14px;flex-wrap:wrap}.dash-att-bars{display:flex;align-items:flex-end;gap:5px;height:72px}.dash-att-bars__col{flex:1;min-width:0;height:100%;display:flex;align-items:flex-end}.dash-att-bars__col--off .dash-att-bars__track{visibility:hidden}.dash-att-bars__track{width:100%;height:100%;display:flex;align-items:flex-end}.dash-att-bars__fill{width:100%;border-radius:4px 4px 2px 2px;background:var(--accent);min-height:4px}.dash-hc-body{display:grid;grid-template-columns:auto 1fr;gap:20px 24px;align-items:center;padding:8px var(--pad) 20px}@media(max-width:520px){.dash-hc-body{grid-template-columns:1fr;justify-items:center}}.dash-hc-donut{position:relative;width:148px;height:148px}.dash-hc-donut__center{position:absolute;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;pointer-events:none}.dash-hc-donut__n{font-size:22px;font-weight:780;letter-spacing:-.03em;line-height:1}.dash-hc-donut__l{font-size:12px;font-weight:600;color:var(--ink-3);margin-top:2px}.dash-hc-legend{list-style:none;margin:0;padding:0;display:flex;flex-direction:column;gap:9px;min-width:0;width:100%}.dash-hc-legend li{display:grid;grid-template-columns:10px 1fr auto;align-items:center;gap:10px;font-size:13px;font-weight:600}.dash-hc-legend__dot{width:10px;height:10px;border-radius:99px}.dash-hc-legend__name{color:var(--ink-2);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.dash-hc-legend__n{font-weight:700;color:var(--ink)}.org-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:210;width:min(440px,94vw);max-height:90vh;max-height:90dvh;overflow-y:auto}.org-form-modal,.leave-type-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);z-index:210;width:min(520px,94vw);max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.org-form-modal__body,.leave-type-modal__body{padding:20px 26px;overflow-y:auto;display:flex;flex-direction:column;gap:16px}.org-form-modal__foot,.leave-type-modal__foot{padding:14px 26px 18px;border-top:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;gap:12px;background:var(--surface)}.segmented--quad .seg-opt{font-size:11.5px;padding:0 6px}.avatar-pick{display:flex;align-items:center;gap:14px;padding:4px 0}.field-note{display:flex;gap:8px;align-items:flex-start;background:var(--accent-softer);border:1px solid color-mix(in oklch,var(--accent) 18%,var(--line));border-radius:10px;padding:11px 13px;font-size:12.5px;color:var(--ink-2);line-height:1.5}.editor-bar{position:sticky;top:0;z-index:30;background:color-mix(in oklch,var(--canvas) 88%,transparent);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);margin:-26px -34px 22px;padding:16px 34px;border-bottom:1px solid var(--line);display:flex;align-items:center;gap:14px}[data-density=compact] .editor-bar{margin:-18px -24px 18px;padding:13px 24px}.crumb{display:flex;align-items:center;gap:7px;font-size:13px;color:var(--ink-3);font-weight:600;white-space:nowrap;min-width:0;overflow:hidden}.crumb .here{color:var(--ink);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.editor-grid{display:grid;grid-template-columns:216px 1fr;gap:30px;align-items:start}.editor-main{min-width:0}.editor-nav{position:sticky;top:96px;display:flex;flex-direction:column;gap:3px}.editor-nav button{display:flex;align-items:center;gap:11px;padding:10px 13px;border-radius:9px;border:none;background:none;font-family:inherit;font-size:13.5px;font-weight:600;color:var(--ink-3);cursor:pointer;text-align:left;transition:background .12s,color .12s}.editor-nav button svg{width:18px;height:18px}.editor-nav button:hover{background:var(--line-2);color:var(--ink)}.editor-nav button.on{background:var(--accent-soft);color:var(--accent-ink)}[data-theme=dark] .editor-nav button.on{color:color-mix(in oklch,var(--accent) 72%,white)}.editor-nav .step-no{width:22px;height:22px;border-radius:99px;border:1.5px solid var(--line);display:grid;place-items:center;font-size:11px;font-weight:700;flex:0 0 22px}.editor-nav button.on .step-no,.editor-nav button.done .step-no{background:var(--accent);border-color:var(--accent);color:#fff}.editor-section{margin-bottom:22px}.save-notice{display:flex;align-items:center;gap:8px;padding:10px 14px;margin-bottom:16px;border-radius:10px;background:var(--ok-soft);color:var(--ok);font-size:13.5px;font-weight:600}.sec-title{font-size:17px;font-weight:730;letter-spacing:-.02em;margin:0 0 3px}.sec-desc{font-size:13px;color:var(--ink-3);margin:0 0 18px}.edu-table-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch;border:1px solid var(--line);border-radius:12px;background:var(--surface);max-width:100%}.edu-table{width:max-content;min-width:100%}.edu-table tbody td{height:auto;padding:10px 12px;vertical-align:top}.edu-table tbody tr{cursor:default}.edu-table tbody tr:hover{background:transparent}.edu-table th:first-child,.edu-table td:first-child{min-width:unset}.edu-table .err{display:block;margin-top:4px}.edu-table-empty{text-align:center;padding:24px;margin:0}.edu-editor-list{display:flex;flex-direction:column;gap:10px;margin-bottom:4px}.edu-editor-card{display:flex;gap:14px;padding:14px 16px;border:1px solid var(--line);border-radius:12px;background:var(--surface-2)}.edu-editor-card__icon{width:42px;height:42px;border-radius:10px;background:var(--surface-2);border:1px solid var(--line-2);color:var(--ok);display:grid;place-items:center;flex-shrink:0}.edu-editor-card__body{flex:1;min-width:0;display:flex;flex-direction:column;gap:4px}.edu-editor-card__title{font-weight:700;font-size:14px;color:var(--ink)}.edu-editor-card__field{font-size:13px}.edu-editor-card__meta{display:flex;align-items:center;gap:8px;font-size:12.5px}.edu-editor-card__meta svg{flex-shrink:0;color:var(--ink-4)}.edu-editor-card__file{display:inline-flex;align-items:center;gap:6px;font-size:12.5px;margin-top:2px}.edu-cert{display:inline-flex;align-items:center;gap:7px;font-size:13px;font-weight:600;color:var(--ok);text-decoration:none;margin-top:2px;width:fit-content}.edu-cert:hover{text-decoration:underline}.edu-editor-form{margin-top:16px;padding:18px;border:1px solid var(--line);border-radius:12px;background:var(--surface)}.edu-editor-form__grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px 18px;margin-bottom:16px}.edu-editor-form__span-2{grid-column:span 2}.edu-editor-form__full{grid-column:1 / -1}.edu-editor-dropzone{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;min-height:120px;padding:20px;border:1.5px dashed var(--line);border-radius:12px;background:var(--surface-2);color:var(--ink-3);cursor:pointer;text-align:center;position:relative;transition:border-color .12s,background .12s}.edu-editor-dropzone:hover:not(.disabled){border-color:color-mix(in oklch,var(--accent) 35%,var(--line));background:var(--surface)}.edu-editor-dropzone.disabled{opacity:.6;pointer-events:none}.edu-editor-dropzone.has-file{border-style:solid;border-color:color-mix(in oklch,var(--ok) 35%,var(--line));background:var(--ok-soft);color:var(--ok)}.edu-editor-dropzone__title{font-size:14px;font-weight:650;color:var(--ink-2)}.edu-editor-dropzone.has-file .edu-editor-dropzone__title{color:var(--ok)}.edu-editor-dropzone__hint{font-size:12px}.edu-editor-dropzone__file{font-size:12.5px;font-weight:600;color:var(--ink-2);max-width:100%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.edu-editor-dropzone.has-file .edu-editor-dropzone__file{color:var(--ok)}.doc-row{display:flex;align-items:center;gap:13px;padding:13px var(--pad);border-bottom:1px solid var(--line-2)}.doc-row:last-child{border-bottom:none}.doc-row--editor{align-items:flex-start}.doc-row--editor .doc-fields{flex:1;min-width:0;display:flex;flex-direction:column;gap:10px}.doc-row--editor .doc-fields-top,.doc-upload{display:flex;align-items:center;gap:10px;flex-wrap:wrap}.doc-upload-btn{position:relative;cursor:pointer}.doc-upload-btn.disabled{opacity:.6;pointer-events:none}.doc-file-input{position:absolute;inset:0;opacity:0;width:100%;height:100%;cursor:pointer}.doc-ic{width:38px;height:38px;border-radius:9px;background:var(--line-2);color:var(--ink-3);display:grid;place-items:center;flex:0 0 38px}.comp-summary{display:grid;grid-template-columns:repeat(3,1fr);gap:1px;background:var(--line);border-radius:var(--r);overflow:hidden}.comp-summary>div{background:var(--surface);padding:16px 18px}.comp-summary .lbl{font-size:12px;color:var(--ink-3);font-weight:600}.comp-summary .val{font-size:21px;font-weight:770;letter-spacing:-.02em;margin-top:4px}.theme-toggle{position:relative;width:105px;height:34px;border:none;border-radius:999px;padding:0;cursor:pointer;background:#e6e6e6;overflow:hidden;flex-shrink:0;transition:background .28s ease}.theme-toggle.is-dark{background:#1a1a1a}.theme-toggle__label{position:absolute;top:50%;transform:translateY(-50%);font-size:9px;font-weight:800;letter-spacing:.04em;line-height:1;pointer-events:none;transition:opacity .22s ease}.theme-toggle__label--day{left:10px;right:auto;color:#111;opacity:1}.theme-toggle__label--night{left:auto;right:10px;color:#fff;opacity:0}.theme-toggle.is-dark .theme-toggle__label--day{opacity:0}.theme-toggle.is-dark .theme-toggle__label--night{opacity:1}.theme-toggle__thumb{position:absolute;top:3px;right:3px;left:auto;width:28px;height:28px;border-radius:50%;background:#fff;display:grid;place-items:center;color:#111;box-shadow:0 1px 5px #00000024;transition:right .28s cubic-bezier(.4,0,.2,1),left .28s cubic-bezier(.4,0,.2,1)}.theme-toggle.is-dark .theme-toggle__thumb{right:auto;left:3px}.theme-toggle__icon{width:15px;height:15px}.theme-toggle:focus-visible{outline:2px solid var(--accent);outline-offset:2px}
