@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Thai:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600;700&display=swap";:root{--accent:#0e7c66;--accent-soft:#e6f4ef;--accent-dark:#0a5c4c;--ink:#15191e;--muted:#6b7280;--bg:#f3f4f6;--surface:#fff;--line:#e5e7eb;--late-bg:#fef3e2;--late-fg:#b45309;--danger-bg:#fee2e2;--danger-fg:#b91c1c;--leave-bg:#eef2ff;--leave-fg:#4338ca;--r-card:16px;--r-card-lg:22px;--r-input:11px;--r-pill:999px;color:var(--ink);background:var(--bg);font-family:IBM Plex Sans Thai,IBM Plex Sans,sans-serif;font-size:15px}*,:before,:after{box-sizing:border-box;margin:0;padding:0}body{-webkit-font-smoothing:antialiased;overflow-x:hidden}.num{font-variant-numeric:tabular-nums;font-family:IBM Plex Sans,monospace}.card{background:var(--surface);border-radius:var(--r-card);border:1px solid var(--line)}.badge{border-radius:var(--r-pill);justify-content:center;align-items:center;padding:2px 8px;font-size:12px;font-weight:600;display:inline-flex}.badge-green{background:var(--accent-soft);color:var(--accent)}.badge-late{background:var(--late-bg);color:var(--late-fg)}.badge-red{background:var(--danger-bg);color:var(--danger-fg)}.badge-leave{background:var(--leave-bg);color:var(--leave-fg)}.btn{border-radius:var(--r-input);cursor:pointer;border:none;justify-content:center;align-items:center;gap:6px;padding:10px 20px;font-family:inherit;font-size:15px;font-weight:600;transition:opacity .15s;display:inline-flex}.btn:disabled{opacity:.45;cursor:not-allowed}.btn-primary{background:var(--accent);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-dark)}.btn-ghost{color:var(--muted);background:0 0}.btn-danger{background:var(--danger-bg);color:var(--danger-fg)}input,select,textarea{color:var(--ink);background:var(--bg);border:1px solid var(--line);border-radius:var(--r-input);outline:none;width:100%;padding:10px 14px;font-family:inherit;font-size:15px;transition:border-color .15s}input:focus,select:focus,textarea:focus{border-color:var(--accent)}.modal-overlay{z-index:100;background:#00000073;justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.modal{background:var(--surface);border-radius:var(--r-card-lg);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;box-shadow:0 30px 70px #0000004d}.sheet-overlay{z-index:90;background:#0006;align-items:flex-end;display:flex;position:fixed;inset:0}.sheet{background:var(--surface);border-radius:24px 24px 0 0;width:100%;max-height:92vh;padding:24px 20px 40px;overflow-y:auto}.admin-shell{max-width:1180px;min-height:100vh;margin:0 auto;display:flex}.admin-sidebar{background:var(--surface);border-right:1px solid var(--line);flex-direction:column;flex-shrink:0;width:220px;height:100vh;display:flex;position:sticky;top:0;overflow-y:auto}.admin-main{flex:1;min-height:100vh;padding:28px;overflow-y:auto}.admin-topbar,.admin-sidebar-overlay{display:none}.admin-menu-btn{border:1px solid var(--line);background:var(--surface);width:42px;height:42px;color:var(--ink);border-radius:12px;font-size:22px;font-weight:700}.admin-sidebar-close{border:1px solid var(--line);background:var(--bg);width:36px;height:36px;color:var(--muted);cursor:pointer;border-radius:10px;font-size:24px;line-height:1;display:none}.payroll-table-card{overflow:hidden}.payroll-table{table-layout:fixed}.payroll-table th,.payroll-table td{vertical-align:middle;overflow-wrap:anywhere;word-break:break-word;padding:10px 8px!important}.payroll-table th{line-height:1.25}.payroll-table td .btn{white-space:nowrap;border-radius:10px;min-height:28px;padding:4px 7px!important}.payroll-table td>div{min-width:0}.payroll-table .num{white-space:nowrap}@media (width<=1024px){.admin-shell{max-width:none;display:block}.admin-topbar{z-index:80;border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);background:#fffffff0;align-items:center;gap:12px;height:60px;padding:10px 16px;display:flex;position:sticky;top:0}.admin-sidebar{z-index:100;width:min(84vw,280px);transition:transform .18s;position:fixed;inset:0 auto 0 0;transform:translate(-105%);box-shadow:18px 0 50px #0003}.admin-sidebar.is-open{transform:translate(0)}.admin-sidebar-overlay{z-index:95;background:#0000006b;border:0;display:block;position:fixed;inset:0}.admin-main{width:100%;min-height:calc(100vh - 60px);padding:18px 16px 28px;overflow-x:auto}.admin-sidebar-close{justify-content:center;align-items:center;display:inline-flex}}::-webkit-scrollbar{width:6px}::-webkit-scrollbar-thumb{background:var(--line);border-radius:99px}
