: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;min-height:38px;padding:0 12px;font-size:.95rem;font-weight:600;transition:background-color .16s,border-color .16s,color .16s;display:inline-flex}.menu-list a:hover,.overflow-trigger:hover{border-color:var(--color-border);background:#ffffffb8}.menu-list a.is-active{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;gap:8px;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(720px,100vw - 48px);box-shadow:var(--shadow-soft);background:#fffffffa;border-radius:8px;padding:16px;position:absolute;top:calc(100% + 12px);right:0}.menu-panel-grid{grid-template-columns:repeat(2,minmax(0,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}.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}.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}.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;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-toolbar label,.task-toolbar label{gap:6px;display:grid}.attendance-toolbar input,.attendance-toolbar 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-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}.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;overflow-x:auto}.attendance-table{border-collapse:collapse;width:100%;min-width:980px}.attendance-table th,.attendance-table td{text-align:center;vertical-align:middle;border-bottom:1px solid #d7dfda;padding:8px}.attendance-table thead th{z-index:1;background:#fffdf8fa;position:sticky;top:0}.attendance-table th:first-child,.attendance-table td:first-child{z-index:2;background:#fffdf8fa;position:sticky;left:0}.attendance-table thead th:first-child{z-index:3}.attendance-select-cell{background:#fffdf8fa;width:52px;min-width:52px}.attendance-table th small{color:#5b6a66;font-size:.72rem;display:block}.attendance-person{text-align:left;color:#32403c;gap:4px;min-width:200px;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:42px;height:42px;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}.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,.dashboard-filter-grid,.task-toolbar,.task-actions-grid{grid-template-columns: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}}
