:root{--color-page:#f4f7f5;--color-page-soft:#edf3ef;--color-surface:#fff;--color-surface-muted:#f7faf8;--color-border:#d8e1dc;--color-border-strong:#b8c9c2;--color-ink:#14211d;--color-muted:#596a64;--color-primary:#0f766e;--color-primary-strong:#0f4f47;--color-primary-soft:#e1f3ed;--color-warm:#b86f18;--shadow-soft:0 18px 46px #1f2d281a;color:var(--color-ink);background:var(--color-page);font-family:Inter,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;font-weight:400;line-height:1.5}*{box-sizing:border-box}body{background:linear-gradient(180deg, var(--color-page) 0%, var(--color-page-soft) 100%);min-width:320px;min-height:100vh;margin:0}a{color:inherit;text-decoration:none}#root{min-height:100vh}.skip-link{z-index:20;background:var(--color-surface);color:var(--color-primary-strong);box-shadow:var(--shadow-soft);border-radius:8px;padding:8px 12px;font-weight:700;position:absolute;top:12px;left:24px;transform:translateY(-140%)}.skip-link:focus{transform:translateY(0)}.shell{min-height:100vh;padding:24px}.topbar,.content,.footer{width:min(1180px,100%);margin:0 auto}.topbar{grid-template-columns:minmax(220px,.65fr) minmax(0,1fr);align-items:center;gap:32px;padding:18px 0 28px;display:grid}.main-nav{justify-content:flex-end;min-width:0;display:flex}.brand-lockup{align-items:center;gap:12px;min-width:220px;display:flex}.brand-mark{background:linear-gradient(135deg, var(--color-primary) 0%, #1d8a73 100%);color:#fff;border-radius:8px;justify-content:center;align-items:center;width:42px;height:42px;font-weight:700;display:inline-flex;box-shadow:0 10px 22px #0f766e2e}.brand-name,.brand-subtitle,.eyebrow,.section-kicker,.footer p{margin:0}.brand-name{letter-spacing:0;font-size:1.1rem;font-weight:700}.brand-subtitle{color:var(--color-muted)}.menu-list{flex-wrap:wrap;justify-content:flex-end;gap:8px;margin:0;padding:0;list-style:none;display:flex}.menu-list a,.overflow-trigger{color:#33433f;white-space:nowrap;background:0 0;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;gap:8px;min-height:38px;padding:0 12px;font-family:inherit;font-size:.95rem;font-weight:600;transition:background-color .16s,border-color .16s,color .16s;display:inline-flex}.menu-link-label{min-width:0}.menu-status-badge{white-space:nowrap;border:1px solid #0000;border-radius:8px;justify-content:center;align-items:center;min-height:20px;padding:0 7px;font-size:.7rem;font-weight:800;line-height:1;display:inline-flex}.menu-status-badge.is-unfinished{color:#6f4a00;background:#fff5d6;border-color:#e5c46b}.menu-status-badge.is-preview{color:#31508c;background:#eef3ff;border-color:#b8c7e8}.menu-list a:hover,.overflow-trigger:hover{border-color:var(--color-border);background:#ffffffb8}.menu-list a.is-active,.overflow-trigger[aria-expanded=true]{background:var(--color-primary-soft);color:var(--color-primary-strong);border-color:#a6d5c8;font-weight:700}.menu-overflow:has(a.is-active) .overflow-trigger{background:var(--color-primary-soft);color:var(--color-primary-strong);border-color:#a6d5c8;font-weight:700}.menu-overflow,.menu-overflow details{position:relative}.overflow-trigger{cursor:pointer;list-style:none}.overflow-trigger::marker{display:none}.overflow-trigger::-webkit-details-marker{display:none}.menu-count{min-width:24px;height:24px;color:var(--color-muted);background:#ecf2ef;border-radius:8px;justify-content:center;align-items:center;padding:0 7px;font-size:.78rem;display:inline-flex}.menu-panel{z-index:30;border:1px solid var(--color-border);width:min(960px,100vw - 48px);max-height:min(72vh,760px);box-shadow:var(--shadow-soft);background:#fffffffa;border-radius:8px;padding:16px;position:absolute;top:calc(100% + 12px);right:0;overflow-y:auto}.menu-panel-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;display:grid}.menu-panel-section{background:var(--color-surface-muted);border-radius:8px;align-content:start;gap:10px;padding:12px;display:grid}.menu-panel-heading .menu-panel-title,.menu-panel-heading p{margin:0}.menu-panel-title{text-transform:uppercase;color:var(--color-primary-strong);font-size:.88rem;font-weight:800}.menu-panel-heading p{color:var(--color-muted);margin-top:3px;font-size:.82rem}.menu-panel-list{flex-wrap:wrap;gap:6px;margin:0;padding:0;list-style:none;display:flex}.menu-panel-list a{border-color:var(--color-border);background:var(--color-surface);min-height:32px;padding:0 10px;font-size:.88rem;font-weight:600}a:focus-visible,button:focus-visible,input:focus-visible,select:focus-visible,textarea:focus-visible{outline-offset:2px;outline:3px solid #0f766e47}.hero{border:1px solid var(--color-border);background:#ffffffdb;border-radius:8px;grid-template-columns:minmax(0,1.6fr) minmax(260px,.9fr);gap:20px;padding:28px;display:grid}.eyebrow,.section-kicker{color:var(--color-primary);text-transform:uppercase;font-size:.8rem;font-weight:700}.hero h1,.panel h2{margin:10px 0 14px;line-height:1.15}.hero h1{max-width:16ch;font-size:clamp(2rem,2vw + 1.2rem,3.3rem)}.hero-copy{color:#33433f;max-width:62ch;margin:0}.status-panel{color:#f6fbf9;background:#153f3a;border-radius:8px;align-content:start;gap:10px;padding:20px;display:grid}.status-panel span{color:#b8d5ce;font-size:.9rem}.status-panel strong{word-break:break-word}.panel-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:16px;margin-top:20px;display:grid}.panel{border:1px solid var(--color-border);background:#ffffffeb;border-radius:8px;padding:22px;box-shadow:0 1px 2px #1f2d280a}.panel.accent{background:var(--color-primary-soft)}.panel p,.panel ul{color:#32403c;margin:0}.page-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.personnel-workspace{gap:14px;width:min(1480px,100vw - 48px);display:grid;position:relative;left:50%;transform:translate(-50%)}.personnel-page-header{justify-content:space-between;align-items:end;gap:18px;display:flex}.personnel-page-header h1,.personnel-drawer-header h2{margin:6px 0 0;line-height:1.1}.personnel-page-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.personnel-page-actions>button{border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;cursor:pointer;border-radius:8px;min-height:38px;padding:0 13px;font-weight:700}.personnel-page-actions>button.secondary-button{color:var(--color-primary);background:0 0}.personnel-page-actions>button:disabled{cursor:not-allowed;opacity:.62}.personnel-filter-panel{padding:14px}.personnel-filter-grid{grid-template-columns:minmax(220px,1.2fr) repeat(5,minmax(140px,1fr)) auto;align-items:end;gap:10px;display:grid}.personnel-filter-grid label{color:#22302d;gap:5px;font-size:.88rem;font-weight:600;display:grid}.personnel-filter-grid input,.personnel-filter-grid select{border:1px solid var(--color-border-strong);background:var(--color-surface);width:100%;min-height:38px;color:var(--color-ink);font:inherit;border-radius:8px;padding:8px 10px}.personnel-filter-actions{align-items:end;display:flex}.personnel-filter-actions .secondary-button{min-height:38px}.personnel-summary-strip{border:1px solid var(--color-border);background:var(--color-border);border-radius:8px;grid-template-columns:repeat(4,minmax(0,1fr));gap:1px;display:grid;overflow:hidden}.personnel-summary-strip div{background:#ffffffeb;justify-content:space-between;align-items:center;gap:14px;min-height:46px;padding:10px 14px;display:flex}.personnel-summary-strip span{color:var(--color-muted);text-transform:uppercase;font-size:.82rem;font-weight:800}.personnel-summary-strip strong{color:var(--color-primary-strong);font-size:1.1rem}.personnel-register-panel{padding:0;overflow:hidden}.personnel-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.personnel-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:1120px}.personnel-table th,.personnel-table td{border-bottom:1px solid var(--color-border);text-align:left;vertical-align:middle;padding:10px 12px}.personnel-table thead th{z-index:1;color:#33433f;text-transform:uppercase;background:#f7faf8fa;font-size:.78rem;font-weight:800;position:sticky;top:0}.personnel-table th:first-child,.personnel-table td:first-child{width:116px}.personnel-table th:nth-child(2),.personnel-table td:nth-child(2){width:250px}.personnel-table th:nth-child(6),.personnel-table td:nth-child(6),.personnel-table th:nth-child(8),.personnel-table td:nth-child(8){width:120px}.personnel-table th:nth-child(7),.personnel-table td:nth-child(7){width:150px}.personnel-group-row th{color:#243631;text-transform:uppercase;background:#eef5f1;padding:7px 12px;font-size:.8rem}.personnel-group-row th,.personnel-group-row th span{letter-spacing:0}.personnel-group-row th{display:table-cell}.personnel-group-row th>span,.personnel-group-row th>strong{align-items:center;min-height:24px;display:inline-flex}.personnel-group-row th>strong{min-width:28px;color:var(--color-primary-strong);background:#fff;border-radius:8px;justify-content:center;margin-left:10px;padding:0 8px}.personnel-number-cell{color:var(--color-muted);font-weight:800}.personnel-name-cell{gap:3px;min-width:0;display:grid}.personnel-name-cell a{color:var(--color-primary-strong);font-weight:800}.personnel-name-cell span{color:var(--color-muted);text-overflow:ellipsis;white-space:nowrap;font-size:.86rem;overflow:hidden}.personnel-flags{flex-wrap:wrap;gap:5px;display:flex}.flag{color:#697771;background:#f3f6f4;border:1px solid #d4ddd8;border-radius:8px;justify-content:center;align-items:center;min-height:26px;padding:0 8px;font-size:.78rem;font-weight:800;display:inline-flex}.flag.is-on{color:var(--color-primary-strong);background:#e1f3ed;border-color:#b7d8cc}.personnel-profile-cell .inline-link{min-height:32px;padding:0 10px;font-weight:700}.personnel-drawer-backdrop{z-index:45;background:#18211f57;justify-content:flex-end;padding:16px;display:flex;position:fixed;inset:0}.personnel-drawer{border:1px solid var(--color-border);background:var(--color-surface);border-radius:8px;align-content:start;gap:16px;width:min(520px,100%);max-height:calc(100vh - 32px);padding:20px;display:grid;overflow:auto;box-shadow:0 22px 60px #1b232138}.personnel-drawer-header{justify-content:space-between;align-items:start;gap:12px;display:flex}.icon-button{border:1px solid var(--color-border);background:var(--color-surface-muted);width:36px;height:36px;color:var(--color-ink);cursor:pointer;border-radius:8px;justify-content:center;align-items:center;font-size:1.25rem;line-height:1;display:inline-flex}.lookup-panel{gap:14px;display:grid}.lookup-list{flex-wrap:wrap;gap:8px;display:flex}.lookup-list span{border:1px solid var(--color-border);background:var(--color-surface-muted);color:#31403c;border-radius:8px;align-items:center;min-height:32px;padding:0 10px;font-size:.9rem;font-weight:700;display:inline-flex}.attendance-workspace{gap:16px;width:min(1600px,100vw - 48px);display:grid;position:relative;left:50%;transform:translate(-50%)}.attendance-workspace .panel{align-self:start}.attendance-page-heading{justify-content:space-between;align-items:start;gap:16px;display:flex}.attendance-page-heading h1,.attendance-page-heading h2{margin:8px 0 0}.attendance-active-status{min-width:140px;color:var(--color-muted);justify-items:end;gap:2px;display:grid}.attendance-active-status strong{color:var(--color-primary-strong)}.dashboard-stack{gap:16px;display:grid}.dashboard-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;display:grid}.dashboard-span-full{grid-column:1/-1}.dashboard-filter-grid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:18px;display:grid}.dashboard-filter-grid label{gap:6px;display:grid}.dashboard-filter-grid input,.dashboard-filter-grid select{border:1px solid var(--color-border-strong);background:var(--color-surface);width:100%;min-height:42px;color:var(--color-ink);border-radius:8px;padding:10px 12px}.dashboard-compact-note{border:1px solid var(--color-border);background:var(--color-surface-muted);border-radius:8px;align-content:center;gap:6px;padding:12px 14px;display:grid}.dashboard-people-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:16px;margin-top:18px;display:grid}.dashboard-table-wrap{overflow-x:auto}.dashboard-table{border-collapse:collapse;width:100%;min-width:720px}.dashboard-table th,.dashboard-table td{border-bottom:1px solid var(--color-border);text-align:left;vertical-align:middle;padding:12px 10px}.dashboard-table th:not(:first-child),.dashboard-table td:not(:first-child){text-align:center}.dashboard-table-person{gap:4px;display:grid}.dashboard-table-person span{color:var(--color-muted);font-size:.9rem}.form-panel{gap:16px;display:grid}.registration-form{gap:12px;display:grid}.registration-form label{color:#22302d;gap:6px;font-size:.95rem;display:grid}.registration-form input,.registration-form select{border:1px solid var(--color-border-strong);background:var(--color-surface);width:100%;min-height:42px;color:var(--color-ink);border-radius:8px;padding:10px 12px}.registration-form textarea{border:1px solid var(--color-border-strong);background:var(--color-surface);width:100%;min-height:96px;color:var(--color-ink);resize:vertical;font:inherit;border-radius:8px;padding:10px 12px}.registration-form button{background:var(--color-primary);color:#fff;cursor:pointer;border:0;border-radius:8px;min-height:44px;font-weight:700}.registration-form button:disabled{cursor:wait;opacity:.75}.lookup-management{gap:10px;display:grid}.compact-inline-form{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;display:grid}.compact-inline-form label{color:#22302d;gap:6px;font-size:.9rem;display:grid}.compact-inline-form input{border:1px solid var(--color-border-strong);background:var(--color-surface);width:100%;min-height:40px;color:var(--color-ink);border-radius:8px;padding:9px 11px}.secondary-button,.inline-link{border:1px solid var(--color-primary);min-height:42px;color:var(--color-primary);background:0 0;border-radius:8px;justify-content:center;align-items:center;padding:0 14px;display:inline-flex}button[data-tooltip]{position:relative}button[data-tooltip]:before,button[data-tooltip]:after{z-index:90;opacity:0;pointer-events:none;visibility:hidden;transition:opacity .14s,transform .14s,visibility .14s;position:absolute;left:50%;transform:translate(-50%)translateY(-2px)}button[data-tooltip]:before{content:"";border-bottom:6px solid #17211f;border-left:6px solid #0000;border-right:6px solid #0000;top:calc(100% + 4px)}button[data-tooltip]:after{color:#fff;content:attr(data-tooltip);text-align:left;white-space:normal;background:#17211f;border:1px solid #ffffff24;border-radius:8px;width:max-content;max-width:min(280px,100vw - 32px);padding:8px 10px;font-size:.78rem;font-weight:700;line-height:1.35;top:calc(100% + 10px);box-shadow:0 12px 26px #17211f38}button[data-tooltip]:hover:before,button[data-tooltip]:hover:after,button[data-tooltip]:focus-visible:before,button[data-tooltip]:focus-visible:after{opacity:1;visibility:visible;transform:translate(-50%)translateY(0)}.form-feedback{min-height:24px;font-size:.95rem}.inline-note{color:var(--color-muted);margin:0}.portal-access-grid{gap:16px;display:grid}.portal-debug-box{border:1px solid var(--color-border);background:var(--color-surface-muted);border-radius:8px;gap:10px;padding:14px;display:grid}.portal-actions{flex-wrap:wrap;gap:10px;display:flex}.filter-feedback{flex-wrap:wrap;align-items:center;gap:10px;margin-top:12px;display:flex}.filter-feedback .inline-note{align-items:center;min-height:32px;display:inline-flex}.panel-header{justify-content:space-between;align-items:start;gap:16px;display:flex}.details-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:14px;margin-top:18px;display:grid}.detail-label{color:var(--color-muted);text-transform:uppercase;margin-bottom:4px;font-size:.82rem;font-weight:700;display:block}.checkbox-group{border:1px solid var(--color-border);background:var(--color-surface-muted);border-radius:8px;gap:8px;padding:12px;display:grid}.checkbox-row{align-items:center;gap:10px;display:flex}.checkbox-row input{width:18px;min-height:18px;margin:0}.inline-fields{grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;display:grid}.directory-list,.history-list{gap:0;display:grid}.directory-row,.history-row{border-top:1px solid #d7dfda;gap:8px;padding:14px 0;display:grid}.selectable-row{text-align:left;width:100%;color:inherit;cursor:pointer;background:0 0;border:0}.selectable-row.is-selected{background:#e1f0ebb8;border-radius:8px;padding-left:12px;padding-right:12px}.directory-row:first-child,.history-row:first-child{border-top:0}.directory-row-head{justify-content:space-between;align-items:center;gap:12px;display:flex}.directory-row-meta{color:#4e5c58;flex-wrap:wrap;align-items:center;gap:8px 12px;font-size:.95rem;display:flex}.status-badge{border:1px solid #c8d3cf;border-radius:8px;justify-content:center;align-items:center;min-height:28px;padding:0 10px;font-size:.84rem;font-weight:700;display:inline-flex}.status-badge.is-active{color:#145548;background:#d9efe6}.status-badge.is-inactive{color:#7a3f2a;background:#f4e6df}.attendance-toolbar{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.attendance-marking-bar{grid-template-columns:minmax(180px,260px) minmax(0,1fr);align-items:end;gap:12px;display:grid}.attendance-toolbar label,.attendance-marking-bar label,.task-toolbar label{gap:6px;display:grid}.attendance-toolbar input,.attendance-toolbar select,.attendance-marking-bar select,.task-toolbar input,.task-toolbar select{color:#162127;background:#fffdf8;border:1px solid #c6d2ce;border-radius:8px;width:100%;min-height:42px;padding:10px 12px}.attendance-status-picker{grid-template-columns:repeat(auto-fit,minmax(112px,1fr));gap:8px;display:grid}.attendance-status-picker button{color:#1f2f2b;cursor:pointer;background:#fffdf8;border:1px solid #c6d2ce;border-radius:8px;grid-template-columns:auto minmax(0,1fr);align-items:center;gap:8px;min-height:42px;padding:8px 10px;display:grid}.attendance-status-picker button span{width:28px;height:28px;color:var(--color-primary-strong);background:#edf3ef;border-radius:8px;justify-content:center;align-items:center;font-weight:800;display:inline-flex}.attendance-status-picker button strong{text-align:left;text-overflow:ellipsis;white-space:nowrap;min-width:0;font-size:.9rem;overflow:hidden}.attendance-status-picker button.is-active{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary-strong)}.attendance-note{grid-column:span 2}.summary-chips{flex-wrap:wrap;gap:10px;display:flex}.summary-chip{background:#f9f7f0eb;border:1px solid #d4ddd8;border-radius:8px;align-items:center;gap:8px;min-height:36px;padding:0 12px;display:inline-flex}.focus-list{gap:10px;display:grid}.focus-item,.empty-state{color:#273632;background:#f9f7f0eb;border:1px solid #d4ddd8;border-radius:8px;gap:6px;padding:12px 14px;display:grid}.focus-link{color:inherit}.task-toolbar{grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:12px;display:grid}.secondary-button:disabled{cursor:not-allowed;opacity:.6}.bulk-action-bar{background:#f9f7f0eb;border:1px solid #d4ddd8;border-radius:8px;gap:12px;padding:14px;display:grid}.task-list{gap:14px;display:grid}.task-row{background:#fffdf8f0;border:1px solid #d4ddd8;border-radius:8px;gap:14px;padding:16px;display:grid}.task-row-head{justify-content:space-between;align-items:start;gap:14px;display:flex}.task-head-main{align-items:start;gap:12px;display:flex}.task-badge-group,.task-action-buttons{flex-wrap:wrap;gap:8px;display:flex}.task-status-badge.is-assigned{color:#145548;background:#e7f2ee}.task-status-badge.is-accepted{color:#1f4f7a;background:#e4eef9}.task-status-badge.is-in-progress{color:#3f5d19;background:#e8f4dd}.task-status-badge.is-completed{color:#145548;background:#d9efe6}.task-status-badge.is-unable,.task-status-badge.is-cancelled,.task-status-badge.is-overdue{color:#7a3f2a;background:#f4e6df}.task-priority-badge.is-low{color:#43514e;background:#edf2ee}.task-priority-badge.is-normal{color:#1f6f61;background:#eef4f2}.task-priority-badge.is-high{color:#8a5612;background:#fff0d8}.task-priority-badge.is-urgent{color:#8c2e28;background:#f4e6df}.task-actions-grid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;display:grid}.task-actions-grid label{gap:6px;display:grid}.task-actions-grid input,.task-actions-grid select{color:#162127;background:#fffdf8;border:1px solid #c6d2ce;border-radius:8px;width:100%;min-height:42px;padding:10px 12px}.task-alert{color:#643526;background:#f8ede8;border:1px solid #e2d0c8;border-radius:8px;padding:10px 12px}.tasks-workspace{gap:14px;width:min(1540px,100vw - 48px);margin-inline:auto;display:grid}.tasks-page-header{justify-content:space-between;align-items:end;gap:18px;display:flex}.tasks-page-header h1,.tasks-table-header h2{margin:6px 0 0;line-height:1.1}.tasks-page-actions,.tasks-table-actions{flex-wrap:wrap;justify-content:flex-end;gap:8px;display:flex}.tasks-page-actions>button{border:1px solid var(--color-primary);background:var(--color-primary);color:#fff;cursor:pointer;border-radius:8px;min-height:38px;padding:0 13px;font-weight:700}.tasks-page-actions>button.secondary-button{color:var(--color-primary);background:0 0}.tasks-summary-strip{border:1px solid var(--color-border);background:var(--color-border);border-radius:8px;grid-template-columns:repeat(6,minmax(0,1fr));gap:1px;display:grid;overflow:hidden}.tasks-summary-strip div{background:#ffffffeb;justify-content:space-between;align-items:center;gap:14px;min-height:46px;padding:10px 14px;display:flex}.tasks-summary-strip span{color:var(--color-muted);text-transform:uppercase;font-size:.82rem;font-weight:800}.tasks-summary-strip strong{color:var(--color-primary-strong);font-size:1.05rem}.tasks-view-tabs{border:1px solid var(--color-border);background:#ffffffeb;border-radius:8px;justify-self:start;align-items:center;gap:4px;padding:4px;display:inline-flex}.tasks-view-tabs button{min-height:34px;color:var(--color-muted);cursor:pointer;background:0 0;border:1px solid #0000;border-radius:8px;padding:0 12px;font-weight:800}.tasks-view-tabs button.is-active{border-color:var(--color-primary);background:var(--color-primary-soft);color:var(--color-primary-strong)}.tasks-history-summary{border:1px solid var(--color-border);background:var(--color-border);border-radius:8px;grid-template-columns:minmax(150px,.7fr) minmax(150px,.7fr) minmax(260px,1.4fr);gap:1px;display:grid;overflow:hidden}.tasks-history-summary div{background:#ffffffeb;justify-content:space-between;align-items:center;gap:14px;min-height:46px;padding:10px 14px;display:flex}.tasks-history-summary span{color:var(--color-muted);text-transform:uppercase;font-size:.82rem;font-weight:800}.tasks-history-summary strong{color:var(--color-primary-strong)}.tasks-filter-panel,.tasks-bulk-bar{padding:14px}.tasks-filter-grid{grid-template-columns:minmax(210px,1.3fr) repeat(2,minmax(150px,.9fr)) minmax(210px,1.2fr) repeat(3,minmax(126px,.8fr)) auto;align-items:end;gap:10px;display:grid}.tasks-history-filter-grid{grid-template-columns:minmax(190px,1.2fr) repeat(2,minmax(130px,.7fr)) repeat(2,minmax(145px,.9fr)) minmax(190px,1.1fr) repeat(3,minmax(125px,.8fr)) auto;align-items:end;gap:10px;display:grid}.tasks-filter-grid label,.tasks-history-filter-grid label,.tasks-bulk-grid label{color:#22302d;gap:5px;font-size:.88rem;font-weight:600;display:grid}.tasks-filter-grid input,.tasks-filter-grid select,.tasks-history-filter-grid input,.tasks-history-filter-grid select,.tasks-bulk-grid input,.tasks-bulk-grid select,.task-row-controls input,.task-row-controls select{border:1px solid var(--color-border-strong);background:var(--color-surface);width:100%;min-height:38px;color:var(--color-ink);font:inherit;border-radius:8px;padding:8px 10px}.tasks-filter-actions{align-items:end;display:flex}.tasks-filter-actions .secondary-button{white-space:nowrap;min-height:38px}.tasks-filter-meta{color:var(--color-muted);flex-wrap:wrap;justify-content:space-between;gap:10px;margin-top:10px;font-size:.88rem;display:flex}.tasks-filter-meta span:first-child{color:var(--color-ink);font-weight:800}.tasks-bulk-title{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:10px;margin-bottom:10px;display:flex}.tasks-bulk-grid{grid-template-columns:minmax(170px,1.2fr) minmax(130px,.7fr) repeat(3,minmax(150px,1fr)) auto;align-items:end;gap:10px;display:grid}.tasks-bulk-actions{flex-wrap:wrap;gap:6px;display:flex}.tasks-bulk-actions .secondary-button{min-height:38px;padding:0 10px}.tasks-table-panel{padding:0;overflow:hidden}.tasks-table-header{border-bottom:1px solid var(--color-border);justify-content:space-between;align-items:end;gap:14px;padding:14px;display:flex}.tasks-table-wrap{-webkit-overflow-scrolling:touch;overflow-x:auto}.tasks-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:1480px}.tasks-history-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:1360px}.tasks-table th,.tasks-table td,.tasks-history-table th,.tasks-history-table td{border-bottom:1px solid var(--color-border);text-align:left;vertical-align:top;padding:9px 10px}.tasks-table thead th,.tasks-history-table thead th{z-index:1;color:#33433f;text-transform:uppercase;background:#f7faf8fa;font-size:.78rem;font-weight:800;position:sticky;top:0}.tasks-table th:first-child,.tasks-table td:first-child{text-align:center;width:42px}.tasks-table th:nth-child(2),.tasks-table td:nth-child(2){width:330px}.tasks-table th:nth-child(3),.tasks-table td:nth-child(3){width:265px}.tasks-table th:nth-child(4),.tasks-table td:nth-child(4){width:112px}.tasks-table th:nth-child(5),.tasks-table td:nth-child(5){width:142px}.tasks-table th:nth-child(6),.tasks-table td:nth-child(6){width:560px}.telegram-filter-grid{grid-template-columns:minmax(260px,1.4fr) minmax(160px,.7fr) auto;align-items:end;gap:10px;display:grid}.telegram-filter-grid label{color:#22302d;gap:5px;font-size:.88rem;font-weight:600;display:grid}.telegram-filter-grid input,.telegram-filter-grid select{border:1px solid var(--color-border-strong);background:var(--color-surface);width:100%;min-height:38px;color:var(--color-ink);font:inherit;border-radius:8px;padding:8px 10px}.telegram-table{min-width:1340px}.telegram-table th:first-child,.telegram-table td:first-child{text-align:left;width:280px}.telegram-table th:nth-child(2),.telegram-table td:nth-child(2){width:150px}.telegram-table th:nth-child(3),.telegram-table td:nth-child(3){width:190px}.telegram-table th:nth-child(4),.telegram-table td:nth-child(4){width:180px}.telegram-table th:nth-child(5),.telegram-table td:nth-child(5){width:310px}.telegram-table th:nth-child(6),.telegram-table td:nth-child(6){width:320px}.telegram-table td{overflow-wrap:anywhere}.telegram-table td>span,.telegram-token-box span{color:var(--color-muted);margin-top:4px;font-size:.84rem;display:block}.telegram-token-box{gap:5px;display:grid}.telegram-token-box .secondary-button{justify-self:start;min-height:30px;padding:0 10px}.tasks-history-table th:first-child,.tasks-history-table td:first-child{width:175px}.tasks-history-table th:nth-child(2),.tasks-history-table td:nth-child(2){width:190px}.tasks-history-table th:nth-child(3),.tasks-history-table td:nth-child(3){width:260px}.tasks-history-table th:nth-child(4),.tasks-history-table td:nth-child(4){width:270px}.tasks-history-table th:nth-child(5),.tasks-history-table td:nth-child(5){width:340px}.tasks-history-table th:nth-child(6),.tasks-history-table td:nth-child(6){width:110px}.task-title-cell,.task-employee-cell,.task-date-cell,.task-state-cell{gap:4px;min-width:0;display:grid}.task-title-cell strong,.task-employee-cell a,.task-date-cell strong{color:var(--color-primary-strong);font-weight:800}.task-title-cell span,.task-title-cell small,.task-employee-cell span,.task-employee-cell small,.task-date-cell span{color:var(--color-muted);font-size:.84rem;line-height:1.35}.task-alert-inline{color:#9e2f29;font-weight:700}.task-state-cell{justify-items:start}.task-row-controls{grid-template-columns:minmax(120px,1fr) 124px minmax(180px,1.25fr);align-items:center;gap:7px;display:grid}.task-row-controls input,.task-row-controls select{min-height:34px;padding:7px 9px}.task-row-controls>div{flex-wrap:wrap;grid-column:1/-1;gap:6px;display:flex}.task-row-controls .secondary-button{min-height:32px;padding:0 9px;font-size:.82rem}.task-history-drawer{width:min(660px,100%)}.task-history-detail-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px;display:grid}.task-history-detail-grid div{border:1px solid var(--color-border);background:var(--color-surface-muted);border-radius:8px;gap:3px;padding:10px 12px;display:grid}.task-history-detail-grid span{color:var(--color-muted);text-transform:uppercase;font-size:.78rem;font-weight:800}.task-history-detail-text{gap:8px;display:grid}.payroll-breakdown-list{margin-top:16px}.payroll-breakdown-grid{grid-template-columns:repeat(auto-fit,minmax(220px,1fr));gap:12px;margin-top:12px;display:grid}.payroll-breakdown-group,.payroll-breakdown-lines{gap:8px;display:grid}.payroll-breakdown-line{background:#fffdf8;border:1px solid #d7dfda;border-radius:8px;gap:4px;padding:10px 12px;display:grid}.payroll-breakdown-line span:last-of-type{font-weight:700}.payroll-breakdown-line small{color:#5a6b66}.task-event-list{gap:10px;display:grid}.task-event-row{border-top:1px solid #dde5e1;justify-content:space-between;align-items:start;gap:16px;padding-top:10px;display:flex}.task-event-row:first-child{border-top:0;padding-top:0}.task-event-row p{margin-top:4px}.selection-check{justify-content:center;align-items:center;width:20px;min-width:20px;margin-top:2px;display:inline-flex}.selection-check input{width:16px;height:16px;margin:0}.sr-only{clip:rect(0, 0, 0, 0);white-space:nowrap;border:0;width:1px;height:1px;margin:-1px;padding:0;position:absolute;overflow:hidden}.attendance-table-wrap{-webkit-overflow-scrolling:touch;background:#fffdf8;border:1px solid #d7dfda;border-radius:8px;overflow-x:auto}.attendance-table{border-collapse:collapse;table-layout:fixed;width:100%;min-width:1380px}.attendance-table th,.attendance-table td{text-align:center;vertical-align:middle;border-bottom:1px solid #d7dfda;padding:6px}.attendance-table thead th{z-index:1;background:#fffdf8fa;position:sticky;top:0}.attendance-group-row th{color:#1f2f2b;letter-spacing:0;text-align:left;text-transform:uppercase;background:#edf5f1;font-size:.78rem;font-weight:800}.attendance-table th:first-child,.attendance-table td:first-child{z-index:2;background:#fffdf8fa;width:48px;min-width:48px;position:sticky;left:0}.attendance-table th:nth-child(2),.attendance-table td:nth-child(2){text-align:left;z-index:2;background:#fffdf8fa;width:250px;min-width:250px;position:sticky;left:48px}.attendance-table thead th:nth-child(2){z-index:3}.attendance-table th:not(:first-child):not(:nth-child(2)),.attendance-table td:not(:first-child):not(:nth-child(2)){width:34px;min-width:34px}.attendance-table thead th:first-child{z-index:3}.attendance-select-cell{background:#fffdf8fa;width:48px;min-width:48px}.attendance-table th small{color:#5b6a66;font-size:.72rem;display:block}.attendance-person{text-align:left;color:#32403c;gap:4px;min-width:0;display:grid}.attendance-person span{color:#5b6a66;font-size:.9rem}.attendance-cell button{color:#1f2f2b;cursor:pointer;background:#fffdf8;border:1px solid #c9d3cf;border-radius:8px;width:30px;height:30px;font-weight:700}.attendance-cell button:disabled{cursor:default;opacity:.7}.attendance-cell.is-present button{color:#145548;background:#d9efe6}.attendance-cell.is-absent button,.attendance-cell.is-unpaid_leave button,.attendance-cell.is-other button{color:#7a3f2a;background:#f4e6df}.attendance-cell.is-paid_leave button,.attendance-cell.is-business_trip button{color:#1f4f7a;background:#e5f0fb}.attendance-cell.is-sick_leave button{color:#53387a;background:#f1ebff}.attendance-cell.is-rest_day button,.attendance-table .is-rest-column{background:#e9eeebeb}.attendance-cell.is-unmarked button{color:#7a8883;background:#fffdf8}.attendance-cell.is-outside button{color:#9aa5a0;background:#f5f2eb}.attendance-cell.is-outside-filter button{color:#8a7b58;background:#f7f0dc}.form-feedback.is-error{color:#9e2f29}.form-feedback.is-success{color:#1f6f61}.panel ul{margin-top:16px;padding-left:20px}.footer{color:#43514e;padding:22px 0 8px}.step-up-backdrop{z-index:40;background:#171f1e94;justify-content:center;align-items:center;padding:20px;display:flex;position:fixed;inset:0}.step-up-dialog{background:#fffdf8;border:1px solid #d4ddd8;border-radius:8px;gap:12px;width:min(100%,420px);padding:20px;display:grid;box-shadow:0 20px 48px #1b23212e}@media (width<=900px){.topbar,.hero,.panel-grid,.page-grid{grid-template-columns:1fr}.main-nav{justify-content:stretch;width:100%}.menu-list{justify-content:flex-start}.menu-panel{width:min(720px,100vw - 32px);left:0;right:auto}.details-grid,.inline-fields,.dashboard-grid,.dashboard-people-grid,.attendance-toolbar,.attendance-marking-bar,.dashboard-filter-grid,.personnel-filter-grid,.tasks-filter-grid,.tasks-history-filter-grid,.tasks-bulk-grid,.task-toolbar,.task-actions-grid{grid-template-columns:1fr}.personnel-workspace,.tasks-workspace{width:100%;left:auto;transform:none}.personnel-page-header,.tasks-page-header,.tasks-table-header{align-items:start;display:grid}.personnel-page-actions,.tasks-page-actions,.tasks-table-actions{justify-content:flex-start}.personnel-summary-strip,.tasks-summary-strip,.tasks-history-summary{grid-template-columns:repeat(2,minmax(0,1fr))}.attendance-note{grid-column:auto}.panel-header,.directory-row-head,.task-row-head,.task-event-row{display:grid}}@media (width<=640px){.shell{padding:16px}.menu-list{flex-wrap:nowrap;padding-bottom:4px;overflow-x:auto}.menu-list a,.overflow-trigger{white-space:nowrap}.menu-panel{width:auto;max-height:calc(100vh - 136px);position:fixed;top:112px;left:16px;right:16px;overflow:auto}.menu-panel-grid{grid-template-columns:1fr}.hero,.panel{padding:18px}.attendance-workspace{width:100%;left:auto;transform:none}.attendance-page-heading{display:grid}.attendance-active-status{justify-items:start}.personnel-summary-strip,.tasks-summary-strip,.tasks-history-summary,.task-history-detail-grid{grid-template-columns:1fr}.personnel-drawer-backdrop{padding:10px}.personnel-drawer{max-height:calc(100vh - 20px)}}
