:root{--paper:#f4efe6;--paper-2:#ece4d6;--card:#fbf8f1;--ink:#1c2433;--ink-soft:#4a5365;--line:#d9cfba;--line-soft:#e6ddcc;--blue:#1f3a5f;--blue-2:#2d5685;--red:#9c2b2b;--green:#2f6b4a;--gold:#b07d2b;--shadow:0 1px 2px rgba(28,36,51,.06),0 8px 24px rgba(28,36,51,.06);--mono:"IBM Plex Mono",ui-monospace,monospace;--sans:"IBM Plex Sans",system-ui,sans-serif;--serif:"Fraunces",Georgia,serif}*{box-sizing:border-box}html,body{height:100%;margin:0}body{background:var(--paper);color:var(--ink);font-family:var(--sans);font-size:14px;-webkit-font-smoothing:antialiased}a{color:var(--blue-2);text-decoration:none;cursor:pointer}a:hover{text-decoration:underline}.app{display:flex;min-height:100vh}.sidebar{width:236px;flex-shrink:0;background:var(--blue);color:#e9e2d2;display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.brand{padding:22px 22px 18px;border-bottom:1px solid rgba(255,255,255,.1)}.brand h1{font-family:var(--serif);font-weight:600;font-size:26px;margin:0;letter-spacing:.5px;color:#fff}.brand span{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:#b9c6d8}.nav{padding:12px 0;overflow-y:auto;flex:1}.nav-section{padding:14px 22px 6px;font-size:10.5px;letter-spacing:1.8px;text-transform:uppercase;color:#8ea1bd}.nav a{display:flex;align-items:center;gap:10px;padding:9px 22px;color:#d4dae6;font-weight:500;font-size:13.5px;border-left:3px solid transparent}.nav a:hover{background:#ffffff0f;text-decoration:none}.nav a.active{background:#ffffff1a;border-left-color:var(--gold);color:#fff}.nav a .ic{width:17px;text-align:center;opacity:.85}.main{flex:1;min-width:0;display:flex;flex-direction:column}.topbar{height:58px;background:var(--card);border-bottom:1px solid var(--line);display:flex;align-items:center;justify-content:space-between;padding:0 28px;gap:12px}.topbar .title{font-family:var(--serif);font-size:20px;font-weight:600}.topbar .co{font-size:12.5px;color:var(--ink-soft)}.content{padding:26px 28px 70px;flex:1}.card{background:var(--card);border:1px solid var(--line);border-radius:8px;box-shadow:var(--shadow);margin-bottom:18px}.card-h{padding:14px 18px;border-bottom:1px solid var(--line-soft);display:flex;align-items:center;justify-content:space-between;gap:10px;flex-wrap:wrap}.card-h h3{margin:0;font-family:var(--serif);font-size:17px;font-weight:600}.card-b{padding:18px}.tiles{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;margin-bottom:22px}.tile{background:var(--card);border:1px solid var(--line);border-radius:8px;padding:16px 18px;box-shadow:var(--shadow);position:relative;overflow:hidden}.tile:after{content:"";position:absolute;right:-20px;top:-20px;width:80px;height:80px;border-radius:50%;background:var(--paper-2);opacity:.5}.tile .k{font-size:11px;letter-spacing:1.5px;text-transform:uppercase;color:var(--ink-soft)}.tile .v{font-family:var(--mono);font-size:25px;font-weight:600;margin-top:6px;position:relative}.tile .v.dr{color:var(--blue)}.tile .v.cr{color:var(--red)}.tile .v.ok{color:var(--green)}.tile .sub{font-size:11px;color:var(--ink-soft);margin-top:3px;position:relative}table.ledger{width:100%;border-collapse:collapse;font-size:13px}table.ledger th{text-align:left;padding:10px 14px;font-size:10.5px;letter-spacing:1.2px;text-transform:uppercase;color:var(--ink-soft);border-bottom:2px solid var(--line);background:var(--paper-2)}table.ledger td{padding:9px 14px;border-bottom:1px solid var(--line-soft)}table.ledger tr:hover td{background:#b07d2b0d}table.ledger .num{font-family:var(--mono);text-align:right}table.ledger .dr{color:var(--blue)}table.ledger .cr{color:var(--red)}table.ledger tfoot td{font-weight:700;border-top:2px solid var(--line);border-bottom:none;background:var(--paper-2)}.muted{color:var(--ink-soft)}label.f{display:block;font-size:11px;letter-spacing:.8px;text-transform:uppercase;color:var(--ink-soft);margin-bottom:5px}input,select,textarea{width:100%;padding:9px 11px;font-size:14px;font-family:var(--sans);background:#fff;border:1px solid var(--line);border-radius:6px;color:var(--ink)}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--blue-2);box-shadow:0 0 0 3px #2d56851f}input.num{font-family:var(--mono);text-align:right}.row{display:grid;gap:14px;margin-bottom:14px}.row.c2{grid-template-columns:1fr 1fr}.row.c3{grid-template-columns:1fr 1fr 1fr}.row.c4{grid-template-columns:1fr 1fr 1fr 1fr}.btn{display:inline-flex;align-items:center;gap:7px;padding:9px 16px;font-size:13.5px;font-weight:600;font-family:var(--sans);border:1px solid var(--blue);background:var(--blue);color:#fff;border-radius:6px;cursor:pointer}.btn:hover{background:var(--blue-2);border-color:var(--blue-2)}.btn.ghost{background:transparent;color:var(--blue)}.btn.ghost:hover{background:#1f3a5f0f}.btn.sm{padding:5px 11px;font-size:12px}.btn:disabled{opacity:.5;cursor:not-allowed}.toolbar{display:flex;gap:10px;align-items:flex-end;flex-wrap:wrap;margin-bottom:18px}.field{min-width:150px}.field.grow{flex:1}.badge{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;letter-spacing:.5px}.badge.dr{background:#1f3a5f1f;color:var(--blue)}.badge.cr{background:#9c2b2b1f;color:var(--red)}.badge.ok{background:#2f6b4a24;color:var(--green)}.badge.warn{background:#b07d2b29;color:var(--gold)}.banner{padding:11px 15px;border-radius:7px;font-size:13px;margin-bottom:16px}.banner.ok{background:#2f6b4a1a;color:var(--green);border:1px solid rgba(47,107,74,.25)}.report-head{display:flex;justify-content:space-between;align-items:baseline;margin-bottom:4px;gap:12px;flex-wrap:wrap}.report-head h2{font-family:var(--serif);font-size:24px;margin:0}.report-sub{color:var(--ink-soft);font-size:12.5px;margin-bottom:18px}.modal-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#1c243366;display:flex;align-items:center;justify-content:center;z-index:50}.modal{background:var(--card);border-radius:10px;width:640px;max-width:92vw;max-height:90vh;overflow:auto;box-shadow:0 20px 60px #0000004d}.modal.wide{width:780px}.modal .card-h h3{font-size:17px}.proto-note{background:#b07d2b1f;color:var(--gold);font-size:12px;padding:6px 14px;text-align:center;font-weight:600;letter-spacing:.4px}.usermenu{display:flex;align-items:center;gap:6px}.bar{height:8px;border-radius:6px;background:var(--paper-2);overflow:hidden}.bar>span{display:block;height:100%;background:var(--blue)}.bar>span.warn{background:var(--gold)}.bar>span.bad{background:var(--red)}.split{display:grid;grid-template-columns:1.4fr 1fr;gap:18px;align-items:start}.topsearch{position:relative;flex:1;max-width:380px;margin:0 16px}.topsearch input{width:100%;padding:8px 12px;border:1px solid var(--line);border-radius:8px;background:var(--paper);font-size:13px;font-family:inherit}.topsearch input:focus{outline:none;border-color:var(--blue-2)}.search-results{display:none;position:absolute;top:calc(100% + 6px);left:0;right:0;background:var(--card);border:1px solid var(--line);border-radius:10px;box-shadow:var(--shadow);z-index:50;max-height:60vh;overflow:auto}.sr-item{display:flex;justify-content:space-between;align-items:center;gap:10px;padding:9px 13px;cursor:pointer;border-bottom:1px solid var(--line-soft)}.sr-item:last-child{border-bottom:none}.sr-item:hover{background:var(--paper-2)}.sr-label{font-weight:600;font-size:13px}.sr-desc{font-size:11.5px;color:var(--ink-soft)}.sr-sec{font-size:10.5px;color:var(--ink-soft);background:var(--paper-2);padding:2px 7px;border-radius:10px;white-space:nowrap}.sr-empty{padding:14px;color:var(--ink-soft);font-size:13px}.menu-btn{display:none;background:none;border:1px solid var(--line);border-radius:6px;width:38px;height:38px;font-size:18px;cursor:pointer;color:var(--ink);align-items:center;justify-content:center}.scrim{display:none}.lc{font-family:var(--mono);font-size:12px}.wh-pill{display:inline-block;font-size:11px;background:var(--paper-2);border:1px solid var(--line-soft);border-radius:20px;padding:1px 8px;margin:1px 2px}.avatar{width:30px;height:30px;border-radius:50%;background:var(--blue);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-size:12px;font-weight:600;flex-shrink:0}.emp-cell{display:flex;align-items:center;gap:10px}.payslip-h{display:flex;justify-content:space-between;align-items:flex-start;border-bottom:2px solid var(--line);padding-bottom:12px;margin-bottom:14px;gap:12px;flex-wrap:wrap}.payslip-grid{display:grid;grid-template-columns:1fr 1fr;gap:18px}@media (max-width:980px){.split{grid-template-columns:1fr}}@media (max-width: 860px){.sidebar{position:fixed;left:0;top:0;z-index:70;transform:translate(-100%);transition:transform .25s ease;box-shadow:4px 0 24px #00000040}.app.nav-open .sidebar{transform:translate(0)}.app.nav-open .scrim{display:block;position:fixed;top:0;right:0;bottom:0;left:0;background:#1c243373;z-index:65}.menu-btn{display:inline-flex}.content{padding:18px 16px 90px}.topbar{padding:0 16px}.topbar .title{font-size:17px}.topbar .co{display:none}.topsearch{max-width:none;margin:0 8px}.tiles{grid-template-columns:repeat(2,1fr)!important;gap:12px}.row.c2,.row.c3,.row.c4,.payslip-grid{grid-template-columns:1fr}.card-b{overflow-x:auto;-webkit-overflow-scrolling:touch}table.ledger{min-width:560px}}@media (max-width:480px){.tiles{grid-template-columns:1fr!important}.brand h1{font-size:23px}}@media print{.sidebar,.topbar,.proto-note,.toolbar,.card-h .btn,.menu-btn{display:none!important}body{background:#fff}.card{box-shadow:none;border:1px solid #ccc}}.tbl-wrap{overflow-x:auto;-webkit-overflow-scrolling:touch}.auth-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--paper);padding:24px}.auth-card{background:var(--card);border:1px solid var(--line);border-radius:12px;box-shadow:var(--shadow);width:420px;max-width:100%;overflow:hidden}.auth-card.wide{width:560px}.auth-head{padding:26px 28px 18px;border-bottom:1px solid var(--line-soft)}.auth-head h1{font-family:var(--serif);font-weight:600;font-size:30px;margin:0;letter-spacing:.5px;color:var(--blue)}.auth-head span{font-size:11px;letter-spacing:2.5px;text-transform:uppercase;color:var(--ink-soft)}.auth-head p{margin:10px 0 0;color:var(--ink-soft);font-size:13px}.auth-body{padding:22px 28px 28px}.auth-body .row{margin-bottom:14px}.auth-foot{margin-top:8px;font-size:13px;color:var(--ink-soft);text-align:center}.auth-err{background:#9c2b2b1a;color:var(--red);border:1px solid rgba(156,43,43,.25);padding:10px 14px;border-radius:7px;font-size:13px;margin-bottom:14px}.btn.block{width:100%;justify-content:center;padding:11px}.co-list{display:grid;gap:12px}.co-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border:1px solid var(--line);border-radius:9px;background:var(--paper);cursor:pointer;transition:border-color .15s,background .15s}.co-item:hover{border-color:var(--blue-2);background:#fff}.co-item .co-name{font-family:var(--serif);font-size:17px;font-weight:600}.co-item .co-meta{font-size:12px;color:var(--ink-soft);margin-top:2px}.co-logo{width:42px;height:42px;border-radius:9px;background:var(--blue);color:#fff;display:inline-flex;align-items:center;justify-content:center;font-family:var(--serif);font-weight:600;font-size:17px;flex-shrink:0}.loading{padding:40px;text-align:center;color:var(--ink-soft);font-size:14px}.att-daily{border-collapse:collapse;font-size:11px;width:auto}.att-daily th,.att-daily td{border:1px solid var(--line-soft)}.att-daily thead th{background:var(--paper);color:var(--ink-soft);font-size:10.5px;text-transform:uppercase;letter-spacing:.4px}.att-daily .emp{text-align:left;padding:6px 10px;white-space:nowrap;position:sticky;left:0;background:var(--card);z-index:2;min-width:150px}.att-daily thead .emp{z-index:3}.att-daily th.day{width:27px;padding:3px 0;text-align:center;font-weight:600}.att-daily th.day .dow{display:block;font-size:9px;color:var(--ink-soft);font-weight:500}.att-daily th.day.we{background:var(--paper-2)}.att-cell{width:27px;height:28px;text-align:center;cursor:pointer;-webkit-user-select:none;user-select:none;font-weight:700;color:#fff;font-size:11px}.att-cell:hover{outline:2px solid var(--blue-2);outline-offset:-2px}.att-cell.blank{color:var(--line);background:transparent}.att-cell.st-p{background:var(--green)}.att-cell.st-pl{background:var(--blue-2)}.att-cell.st-lwp{background:var(--red)}.att-cell.st-h{background:#b07d2b}.att-cell.st-wo{background:#8a8a8a}.att-daily td.att-tot{padding:0 8px;text-align:center;font-family:var(--mono);background:var(--paper)}.att-daily td.att-tot.pay{font-weight:700;color:var(--blue)}.att-legend{display:flex;gap:16px;flex-wrap:wrap;font-size:12px;align-items:center;margin:2px 0 14px;color:var(--ink-soft)}.att-legend .sw{display:inline-block;width:14px;height:14px;border-radius:3px;vertical-align:-2px;margin-right:6px}.att-legend .sw.st-p{background:var(--green)}.att-legend .sw.st-pl{background:var(--blue-2)}.att-legend .sw.st-lwp{background:var(--red)}.att-legend .sw.st-h{background:#b07d2b}.att-legend .sw.st-wo{background:#8a8a8a}.att-cell{position:relative}.att-cell.from-leave:after{content:"";position:absolute;top:2px;right:2px;width:4px;height:4px;border-radius:50%;background:#ffffffe6}
