:root{--bg:#f6f7f9;--panel:#fff;--soft:#eef6f1;--line:#dce3df;--text:#18211d;--muted:#68756e;--primary:#17633d;--primary-dark:#0f4c2f;--primary-soft:#e2f3ea;--warning:#f6e8bd;--shadow:0 12px 32px rgba(21,41,31,.08)}*{box-sizing:border-box}body,html{min-height:100%}body{margin:0;background:var(--bg);color:var(--text);font-family:Inter,Noto Sans JP,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;letter-spacing:0}a{color:inherit;text-decoration:none}button,input,select,textarea{font:inherit}button{border:0;cursor:pointer}button:disabled{cursor:not-allowed;opacity:.45}input,select,textarea{width:100%;border:1px solid var(--line);border-radius:8px;background:#fff;color:var(--text);padding:10px 12px}textarea{min-height:92px;resize:vertical}.loginPage{display:grid;min-height:100vh;place-items:center;padding:24px;background:linear-gradient(180deg,rgba(226,243,234,.8),rgba(246,247,249,.9)),var(--bg)}.loginPanel{width:min(440px,100%);border:1px solid var(--line);border-radius:10px;background:var(--panel);box-shadow:var(--shadow);padding:32px}.brandIcon,.brandMark{display:inline-grid;place-items:center;border-radius:8px;background:var(--primary);color:#fff;font-weight:800}.brandMark{width:48px;height:48px;margin-bottom:16px}.loginPanel h1{margin:0 0 8px;font-size:24px}.loginPanel p,.muted{color:var(--muted)}.formGrid,.loginForm,.stack{display:grid;gap:16px}.loginForm{margin-top:24px}.formGrid label,.loginForm label{display:grid;gap:8px}.formGrid label span,.loginForm label span{font-size:13px;font-weight:700}.passwordField{position:relative}.passwordField input{padding-right:76px}.loginForm .passwordToggle{position:absolute;top:50%;right:8px;min-width:56px;border-radius:6px;background:var(--primary-soft);color:var(--primary-dark);font-size:12px;font-weight:800;padding:6px 8px;transform:translateY(-50%)}.loginForm button,.primaryButton,.requestForm button{border-radius:8px;background:var(--primary);color:#fff;font-weight:800;padding:12px 16px}.formMessage{margin:18px 0 0;color:var(--primary-dark);font-weight:700}.formMessage.error{color:#9f2f2f}.formMessage.success{color:var(--primary-dark)}.loginSupport{display:flex;justify-content:center;margin-top:18px}.linkButton,.textLink{background:transparent;color:var(--primary-dark);font-weight:800;text-decoration:underline;text-underline-offset:3px}.linkButton{padding:0}.appHeader{position:sticky;top:0;z-index:10;display:grid;grid-template-columns:minmax(220px,1fr) auto auto;gap:16px;border-bottom:1px solid var(--line);background:hsla(0,0%,100%,.96);padding:12px 24px;backdrop-filter:blur(8px)}.appHeader,.brand{align-items:center}.brand{display:flex;min-width:0;gap:12px}.brandIcon{width:40px;height:40px;flex:0 0 auto}.brand small,.brand strong{display:block}.brand small{color:var(--muted);font-size:12px}.actionRow,.inlineActions,.navTabs,.userBox{display:flex;align-items:center;gap:8px}.navTabs{overflow-x:auto}.ghostButton,.navTabs a,.pill{border-radius:8px;padding:8px 10px;white-space:nowrap}.navTabs a{color:var(--muted);font-weight:700}.navTabs a.active{background:var(--primary);color:#fff}.userBox{justify-content:flex-end}.pill{background:var(--warning);color:#5c4310;font-size:12px;font-weight:800}.ghostButton{border:1px solid var(--line);background:#fff;color:var(--text)}.sidebarBackdrop,.sidebarToggle{display:none}.appLayout{display:grid;grid-template-columns:260px minmax(0,1fr);min-height:100vh}.sidebar{position:sticky;top:0;display:flex;height:100dvh;flex-direction:column;justify-content:space-between;gap:20px;border-right:1px solid var(--line);background:hsla(0,0%,100%,.96);padding:20px 16px;overflow-y:auto;backdrop-filter:blur(8px)}.sideNav,.sideNavGroup,.sidebarFooter,.sidebarProfile,.sidebarTop{display:grid}.sidebarTop{gap:18px;min-width:0}.sidebarProfile{gap:14px;min-width:0}.sidebarName{display:block;min-width:0;font-size:18px;overflow-wrap:anywhere}.sidebarBrand{align-items:flex-start;border-bottom:1px solid var(--line);padding-bottom:16px}.sideNav,.sideNavGroup{gap:6px}.sideNav a{border-radius:8px;color:var(--muted);font-weight:800;padding:10px 12px}.sideNav a.active{background:var(--primary);color:#fff}.sideNavGroup{border-top:1px solid var(--line);margin-top:8px;padding-top:12px}.sideNavLabel{color:var(--muted);font-size:12px;font-weight:800;padding:0 12px 2px}.sidebarFooter{gap:10px}.rolePill,.sidebarLogout{display:inline-flex;align-items:center;width:100%;justify-content:center;text-align:center}.pageShell{width:min(1180px,100%);margin:0 auto;padding:28px 20px 48px}.appMain{min-width:0}.heroBand,.panel,.summary{border:1px solid var(--line);border-radius:10px;background:var(--panel);box-shadow:var(--shadow)}.heroBand{display:flex;align-items:center;justify-content:space-between;gap:20px;padding:28px}.heroBand h1,.panel h1,.panel h2{margin:0 0 10px}.eyebrow{margin:0 0 8px;color:var(--primary);font-size:13px;font-weight:800}.secondaryButton{border:1px solid var(--primary);border-radius:8px;background:var(--primary-soft);color:var(--primary-dark);font-weight:800;padding:12px 16px}.gridTwo{display:grid;grid-template-columns:minmax(0,1fr) minmax(0,1fr);gap:18px}.panel{min-width:0;padding:20px}.panelHeader{display:flex;align-items:flex-start;justify-content:space-between;gap:16px;margin-bottom:14px}.panelHeader .primaryButton{flex:0 0 auto}.compactHeader{margin-bottom:8px}.compactHeader h2{margin-bottom:4px}.segmentedControl{display:inline-flex;align-items:center;gap:4px;border:1px solid var(--line);border-radius:8px;background:#f2f5f3;padding:4px}.segmentedControl button{min-height:34px;border-radius:6px;background:transparent;color:var(--muted);font-weight:800;padding:7px 12px;white-space:nowrap}.segmentedControl button.active{background:#fff;color:var(--primary-dark);box-shadow:0 1px 3px rgba(21,41,31,.12)}.filterBar{display:flex;align-items:end;flex-wrap:wrap;gap:10px}.filterBar label{display:grid;gap:6px;min-width:150px}.filterBar label span{color:var(--muted);font-size:12px;font-weight:800}.statusButton{display:inline-flex;min-width:136px;align-items:center;justify-content:center;gap:8px;transition:background .16s ease,box-shadow .16s ease,transform .16s ease}.statusButton:disabled{opacity:1}.statusButton[data-state=saving]{background:#b7791f;color:#fff;box-shadow:0 10px 22px rgba(183,121,31,.22)}.statusButton[data-state=saved]{background:#208a4d;color:#fff;box-shadow:0 10px 22px rgba(32,138,77,.24);transform:translateY(-1px)}.buttonSpinner{width:14px;height:14px;border:2px solid hsla(0,0%,100%,.45);border-top-color:#fff;border-radius:999px;animation:spin .72s linear infinite}.toast{position:fixed;top:82px;right:20px;z-index:40;display:grid;max-width:min(360px,calc(100vw - 32px));gap:2px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 18px 42px rgba(21,41,31,.16);padding:14px 16px;animation:toastIn .18s ease-out}.toast strong{font-size:14px}.toast span{color:var(--muted);font-size:12px}.toast[data-state=saving]{border-color:#e5b94f;background:#fff8e6}.toast[data-state=saved]{border-color:#8fd1ad;background:#f0fbf5}@keyframes spin{to{transform:rotate(1turn)}}@keyframes toastIn{0%{opacity:0;transform:translateY(-8px)}to{opacity:1;transform:translateY(0)}}.metrics{display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:12px;margin:0}.metrics div,.summary{background:var(--soft);padding:16px}.metrics dt,.summary span{color:var(--muted);font-size:12px;font-weight:700}.metrics dd,.summary strong{display:block;margin:6px 0 0;font-size:22px;font-weight:800}.requestForm{display:grid;grid-template-columns:150px 130px minmax(220px,1fr) 110px;gap:10px;margin:14px 0}.expenseForm{display:grid;gap:14px}.expenseLine,.expenseLines{display:grid;gap:10px}.expenseLine{grid-template-columns:minmax(110px,150px) minmax(180px,1fr) auto auto;align-items:end;border:1px solid var(--line);border-radius:8px;background:#f8faf8;padding:10px}.expenseLine label{display:grid;gap:6px}.expenseLine label span,.lineNumber{font-size:12px;font-weight:800}.lineNumber{min-width:28px;padding-bottom:10px;text-align:right}.correctionForm{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:14px}.correctionForm label{display:grid;gap:8px}.correctionForm label span{font-size:13px;font-weight:700}.wideField{grid-column:span 2}.fullField{grid-column:1/-1}.correctionMessage{margin:14px 0 0;border-radius:8px;padding:10px 12px;font-weight:800}.correctionMessage[data-state=saved]{background:#f0fbf5;color:#16623b}.correctionMessage[data-state=requested]{background:#fff8e6;color:#7a4f12}.correctionMessage[data-state=error]{background:#fff0f0;color:#8a1f1f}.summaryGrid{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:14px}.hourlyRateGrid{margin-top:16px}.hourlyRateNote{margin-top:14px}.tableWrap{width:100%;overflow-x:auto}table{width:100%;min-width:1160px;border-collapse:collapse}td,th{border-bottom:1px solid var(--line);padding:12px 10px;text-align:left;vertical-align:middle}th{color:var(--muted);font-size:12px;font-weight:800}tbody tr:hover{background:#fbfcfb}td button{border:1px solid var(--line);border-radius:7px;background:#fff;padding:7px 10px}td input,td select{min-width:92px}td input:disabled{background:#f3f5f3;color:var(--muted);cursor:not-allowed}.settingsTable .tableWrap{border:1px solid var(--line);border-radius:8px}.settingsTable table{min-width:940px}.settingsTable th{background:#f8faf8}.settingsTable td:first-child,.settingsTable th:first-child{min-width:140px;font-weight:800}.staffSettingsTable table{min-width:1880px}.tableCheckbox{display:inline-flex;align-items:center;gap:6px;color:var(--text);font-weight:800;white-space:nowrap}.tableCheckbox input{min-width:0;width:auto}.accountForm{border:1px solid var(--line);border-radius:8px;background:#f8faf8;padding:16px}.accountForm,.accountStack{display:grid;gap:16px}.accountListPanel{border:1px solid var(--line);border-radius:8px;background:#fff;padding:16px}.accountListTable table{min-width:1480px}.accountListTable td:first-child,.accountListTable th:first-child{min-width:140px;font-weight:800}.accountListTable td:nth-child(2),.accountListTable th:nth-child(2){min-width:240px;overflow-wrap:anywhere}.inlinePasswordResetForm{display:grid;grid-template-columns:minmax(180px,1fr) auto;align-items:start;gap:8px;min-width:360px}.inlinePasswordResetForm .statusButton{min-width:104px;min-height:42px;padding:10px 12px}.compactMessage{grid-column:1/-1;font-size:12px}.categoryForm{display:grid;grid-template-columns:minmax(220px,1fr) auto;align-items:end;gap:12px;margin-bottom:14px}.categoryChips{display:flex;flex-wrap:wrap;gap:8px}.categoryChip{display:inline-flex;align-items:center;gap:8px;border:1px solid var(--line);border-radius:999px;background:#f8faf8;padding:6px 8px 6px 12px;font-weight:800}.chipRemoveButton{border:0;border-radius:999px;background:#e6eee8;color:var(--primary-dark);cursor:pointer;font-weight:800;padding:5px 8px}.chipRemoveButton:disabled{cursor:not-allowed;opacity:.45}.developerBootstrapForm{background:#fffaf0}.accountGrid,.tenantProfileGrid{grid-template-columns:repeat(3,minmax(0,1fr))}.personalProfileGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.commutingPassGrid{grid-template-columns:minmax(180px,260px) minmax(0,1fr);align-items:start}.payrollControlGrid{display:grid;grid-template-columns:minmax(160px,220px) minmax(150px,190px) auto auto;align-items:end;gap:12px}.payrollControlGrid label{display:grid;gap:6px}.checkboxLabel span,.payrollControlGrid label span{color:var(--muted);font-size:12px;font-weight:800}.checkboxLabel{display:inline-flex!important;width:auto;align-items:center;gap:8px;min-height:42px}.checkboxLabel input{width:auto}.payrollTable table{min-width:1560px}.payrollSlipGrid{display:grid;grid-template-columns:repeat(5,minmax(0,1fr));gap:12px}.accountActions{display:flex;align-items:center;gap:14px}.accountMessage{margin:0}.accountMessage[data-state=error]{color:#9f2f2f}.accountMessage[data-state=saved]{color:var(--primary-dark)}.statusBadge{display:inline-flex;align-items:center;border-radius:999px;font-size:12px;font-weight:800;padding:5px 9px;white-space:nowrap}.statusBadge.pending{background:#fff8e6;color:#7a4f12}.statusBadge.approved{background:#e9f8ef;color:#17633d}.statusBadge.rejected{background:#fff0f0;color:#8a1f1f}.statusBadge.returned{background:#fff3e6;color:#8a4b12}.statusBadge.notStarted{background:#f1f4f2;color:#59645e}.statusBadge.working{background:#e8f5ff;color:#135a82}.statusBadge.completed{background:#e9f8ef;color:#17633d}.staffStatusPanelHeader{display:grid;grid-template-columns:minmax(0,1fr) auto;align-items:start}.staffStatusPanelHeader .filterBar{grid-column:1/-1;justify-content:flex-end}.staffStatusHeaderActions{display:flex;align-items:center;gap:10px;flex-wrap:nowrap}.staffStatusHeaderActions span{min-width:42px;color:var(--muted);font-size:13px;font-weight:800;text-align:right}.staffStatusTable .tableWrap{overflow-x:visible}.staffStatusTable table{min-width:0;table-layout:fixed}.staffStatusTable td,.staffStatusTable th{padding:10px 6px;overflow-wrap:anywhere}.staffStatusDateColumn{width:6%}.staffStatusNameColumn{width:10%}.staffStatusWorkStyleColumn{width:8%}.staffStatusDayStatusColumn{width:10%}.staffStatusClockStatusColumn{width:8%}.staffStatusExpenseColumn,.staffStatusMinutesColumn,.staffStatusTimeColumn{width:10%}.staffStatusShiftColumn{width:8%}.attendanceTimeInput,.dayStatusSelect,.expenseAmountInput,.shiftApplyButton{width:100%;min-width:0}.shiftApplyButton{border-color:#9ed2b3;background:#f5fbf7;color:#17633d;font-weight:800}.staffStatusResultList{display:grid;gap:6px;margin-top:12px}.staffStatusResultList span{border-radius:7px;padding:8px 10px;font-size:12px;font-weight:800;line-height:1.4}.staffStatusResultList span[data-state=saved]{background:#eef9f2;color:#17633d}.staffStatusResultList span[data-state=error]{background:#fff0f0;color:#8a1f1f}.approvalsTable table{min-width:1120px}.approvalsTable td:last-child,.approvalsTable th:last-child{width:132px;min-width:132px}.approvalsTable td:nth-child(5),.approvalsTable th:nth-child(5){min-width:220px;overflow-wrap:anywhere}.approvalActions{flex-wrap:nowrap;min-width:max-content}.approvalActions button{min-width:52px}.staffStatusTable td:first-child,.staffStatusTable th:first-child{min-width:0;font-weight:800}.attendanceHistoryTable table{min-width:1040px}.monthlySummaryTable table{min-width:920px}.developerShell{display:grid;gap:18px}.developerLogoutButton{justify-self:end;min-width:132px}.developerGrid{align-items:start}.developerFormGrid{grid-template-columns:1fr}.developerTable table{min-width:820px}.approveButton{border-color:#9ed2b3;background:#eef9f2;color:#17633d;font-weight:800}.rejectButton{border-color:#f0b5b5;background:#fff5f5;color:#8a1f1f;font-weight:800}@media (max-width:900px){.appHeader{grid-template-columns:1fr}.userBox{justify-content:flex-start;flex-wrap:wrap}.appLayout{grid-template-columns:180px minmax(0,1fr)}.sidebar{height:100dvh;border-right:1px solid var(--line);border-bottom:0;padding:14px 10px}.sidebarProfile,.sidebarTop{gap:12px}.sidebarBrand{padding-bottom:12px}.sideNav,.sideNavGroup,.sidebarFooter{grid-template-columns:1fr}.sideNav a{white-space:normal}.rolePill{width:100%}.gridTwo,.heroBand{grid-template-columns:1fr}.heroBand{align-items:stretch;flex-direction:column}.actionRow{display:grid;grid-template-columns:1fr 1fr}.summaryGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.correctionForm,.expenseLine,.requestForm{grid-template-columns:1fr}.lineNumber{display:none}.wideField{grid-column:1}.panelHeader{align-items:stretch;flex-direction:column}.filterBar{display:grid;grid-template-columns:1fr}.filterBar label{min-width:0}.segmentedControl{width:100%}.segmentedControl button{flex:1}.accountGrid,.categoryForm,.commutingPassGrid,.payrollControlGrid,.payrollSlipGrid,.personalProfileGrid,.tenantProfileGrid{grid-template-columns:1fr}.accountActions{align-items:stretch;flex-direction:column}}@media (max-width:560px){.loginPanel{padding:24px}.appLayout{grid-template-columns:minmax(0,1fr)}.sidebarToggle{position:fixed;top:12px;left:12px;z-index:90;display:inline-grid;width:44px;height:44px;place-items:center;gap:4px;border:1px solid var(--line);border-radius:8px;background:#fff;box-shadow:0 10px 24px rgba(21,41,31,.16);padding:10px}.sidebarToggle span{display:block;width:20px;height:2px;border-radius:999px;background:var(--primary-dark);transition:transform .16s ease,opacity .16s ease}.appLayout[data-sidebar-open=true] .sidebarToggle span:first-child{transform:translateY(6px) rotate(45deg)}.appLayout[data-sidebar-open=true] .sidebarToggle span:nth-child(2){opacity:0}.appLayout[data-sidebar-open=true] .sidebarToggle span:nth-child(3){transform:translateY(-6px) rotate(-45deg)}.sidebarBackdrop{position:fixed;inset:0;z-index:70;display:block;border:0;background:rgba(13,24,18,.38);opacity:0;pointer-events:none;transition:opacity .16s ease}.appLayout[data-sidebar-open=true] .sidebarBackdrop{opacity:1;pointer-events:auto}.sidebar{position:fixed;z-index:80;top:0;left:0;width:min(82vw,280px);gap:12px;border-right:1px solid var(--line);box-shadow:18px 0 42px rgba(21,41,31,.18);padding:64px 14px 14px;transform:translateX(-100%);visibility:hidden;transition:transform .18s ease,visibility .18s ease}.appLayout[data-sidebar-open=true] .sidebar{transform:translateX(0);visibility:visible}.sidebarName{font-size:18px;text-align:left}.sidebarBrand{justify-content:flex-start;padding-bottom:10px}.sidebarBrand>span:last-child{display:block}.brandIcon{width:40px;height:40px}.sideNav a{font-size:14px;padding:10px 12px;text-align:left}.sideNavLabel{padding:0 12px 2px;text-align:left}.rolePill,.sidebarLogout{font-size:12px;padding:8px 10px}.pageShell{padding:70px 12px 32px}.metrics,.summaryGrid{grid-template-columns:1fr}}