:root{--blue:#18407b;--blue-2:#1a9fe0;--ink:#1c2530;--muted:#6b7785;--line:#d8dee7;--bg:#eef1f5;--card:#fff;--ok:#1f9d57;--err:#d23b3b;--shadow:0 1px 3px #14285014,0 6px 24px #14285012}*{box-sizing:border-box}html,body,#app{height:100%;margin:0}body{color:var(--ink);background:var(--bg);font-family:system-ui,-apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif;line-height:1.4}.shell{grid-template-columns:236px 1fr;min-height:100vh;display:grid}.sidebar{background:var(--blue);color:#fff;flex-direction:column;height:100vh;padding:18px 14px;display:flex;position:sticky;top:0}.sidebar .brand{border-bottom:1px solid #ffffff26;align-items:center;gap:11px;margin-bottom:12px;padding:4px 8px 18px;display:flex}.sidebar .brand .logo{background:linear-gradient(135deg,var(--blue-2),#0d2f63);border-radius:9px;flex:none;place-items:center;width:38px;height:38px;font-size:19px;font-weight:800;display:grid}.sidebar .brand h1{letter-spacing:.4px;margin:0;font-size:17px}.sidebar .brand h1 small{opacity:.75;letter-spacing:.3px;font-size:10px;font-weight:400;display:block}.nav{flex-direction:column;flex:1;gap:3px;display:flex}.nav a{color:#dfe8f4;border-radius:9px;align-items:center;gap:11px;padding:10px 12px;font-size:14px;font-weight:500;text-decoration:none;transition:background .12s;display:flex}.nav a .ic{text-align:center;opacity:.9;width:20px}.nav a:hover{background:#ffffff17}.nav a.active{color:var(--blue);background:#fff;font-weight:700}.sidebar .foot{opacity:.9;border-top:1px solid #ffffff26;padding-top:12px;font-size:12px}.sidebar .foot .u{text-overflow:ellipsis;white-space:nowrap;margin-bottom:2px;font-weight:600;display:block;overflow:hidden}.sidebar .foot button{color:#fff;background:#ffffff1f;border:none;width:100%;margin-top:8px}.sidebar .foot button:hover{background:#ffffff38}.content{max-width:1080px;padding:26px 30px 70px}.page-title{align-items:center;gap:12px;margin:0 0 6px;display:flex}.page-title h2{color:var(--blue);letter-spacing:.3px;margin:0;font-size:22px}.page-sub{color:var(--muted);margin:0 0 18px;font-size:13px}@media (width<=820px){.shell{grid-template-columns:1fr}.sidebar{flex-flow:wrap;align-items:center;height:auto;padding:12px;position:static}.sidebar .brand{border:none;margin:0;padding:0 12px 0 4px}.nav{flex-flow:wrap;flex:1}.nav a{padding:8px 10px}.sidebar .foot{border:none;padding:0}.content{padding:18px}}.card{background:var(--card);box-shadow:var(--shadow);border-radius:14px;margin-top:18px;padding:20px 22px}.card:first-of-type{margin-top:0}.card h3{text-transform:uppercase;letter-spacing:.8px;color:var(--muted);margin:0 0 14px;font-size:13px}label{color:var(--muted);margin-bottom:5px;font-size:12px;font-weight:600;display:block}label .en{color:var(--blue-2);font-style:italic;font-weight:500}input,select,textarea{width:100%;font:inherit;color:var(--ink);border:1px solid var(--line);background:#fff;border-radius:9px;padding:9px 11px}input:focus,select:focus,textarea:focus{border-color:var(--blue-2);outline:none;box-shadow:0 0 0 3px #1a9fe02e}input[readonly]{color:var(--muted);background:#f4f6f9}.row{gap:12px 16px;display:grid}.row.c2{grid-template-columns:repeat(2,1fr)}.row.c3{grid-template-columns:repeat(3,1fr)}.row.c4{grid-template-columns:repeat(4,1fr)}@media (width<=720px){.row.c2,.row.c3,.row.c4{grid-template-columns:1fr}}button{font:inherit;cursor:pointer;border:1px solid #0000;border-radius:10px;align-items:center;gap:8px;padding:10px 16px;font-weight:600;display:inline-flex}button.primary{background:var(--blue);color:#fff}button.primary:hover{background:#102f5e}button.accent{background:var(--blue-2);color:#fff}button.accent:hover{background:#1488c2}button.ghost{color:var(--blue);border-color:var(--line);background:#fff}button.ghost:hover{border-color:var(--blue-2);color:var(--blue-2)}button.danger{color:var(--err);border-color:var(--line);background:#fff}button.danger:hover{border-color:var(--err)}button.tiny{padding:7px 11px;font-size:13px}button:disabled{opacity:.5;cursor:default}.tablewrap{overflow-x:auto}table{border-collapse:separate;border-spacing:0;width:100%}th{text-transform:uppercase;letter-spacing:.4px;color:#fff;background:var(--blue);text-align:left;white-space:nowrap;padding:9px 8px;font-size:11px}th .en{opacity:.82;text-transform:none;font-size:10px;font-style:italic;font-weight:400;display:block}th:first-child{border-top-left-radius:9px}th:last-child{border-top-right-radius:9px}td{border-bottom:1px solid var(--line);vertical-align:middle;padding:8px}tr.weekend td{background:#f6f8fb}.right{text-align:right}.total{color:var(--blue);font-variant-numeric:tabular-nums;font-size:26px;font-weight:800}.pill{text-transform:capitalize;border-radius:99px;padding:2px 9px;font-size:11px;font-weight:600}.pill.draft{color:var(--muted);background:#eef1f5}.pill.submitted{color:var(--blue-2);background:#e6f3fb}.pill.approved{color:var(--ok);background:#e6f6ec}.pill.locked{color:var(--err);background:#fde9e9}.signin{text-align:center;max-width:400px;margin:14vh auto}.signin .logo{background:linear-gradient(135deg,var(--blue-2),#0d2f63);color:#fff;border-radius:16px;place-items:center;width:64px;height:64px;margin:0 auto 20px;font-size:30px;font-weight:800;display:grid}.signin h1{color:var(--blue);margin:0 0 6px;font-size:26px}.signin p{color:var(--muted);margin:0 0 24px}.err-box{border:1px solid var(--err);color:#a12;background:#fde9e9;border-radius:10px;margin-top:14px;padding:10px 14px;font-size:13px}.ok-box{border:1px solid var(--ok);color:#176c3d;background:#e6f6ec;border-radius:10px;margin-top:14px;padding:10px 14px;font-size:13px}.muted{color:var(--muted)}.hint{color:var(--muted);margin:8px 2px 0;font-size:12px}.tag{color:var(--blue);background:#e6f3fb;border-radius:99px;margin:2px 4px 2px 0;padding:2px 8px;font-size:11px;font-weight:600;display:inline-block}.empty{text-align:center;color:var(--muted);padding:22px}
