:root{--bg:#eef1f6;--panel:#fff;--panel-2:#f5f7fb;--line:#e4e9f1;--line-2:#eef2f8;--ink:#15233b;--muted:#5d6b85;--soft:#93a0b8;--accent:#ea7a17;--accent-600:#cf6a0a;--accent-bg:#fdf1e3;--blue:#2563eb;--green:#16a34a;--amber:#d97706;--red:#dc2626;--grey:#64748b;--green-bg:#e6f5ec;--amber-bg:#fdf1de;--red-bg:#fdeaea;--grey-bg:#eef1f6;--blue-bg:#e8eefc;--shadow:0 1px 2px #101e360d,0 6px 20px #101e360d;--shadow-lg:0 12px 40px #101e362e;--r:12px}*{box-sizing:border-box;margin:0;padding:0}html,body{height:100%}body{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Helvetica,Arial,sans-serif;font-size:13.5px;line-height:1.5}a{color:inherit;text-decoration:none}button{cursor:pointer;color:inherit;background:0 0;border:none;font-family:inherit}input,select,textarea{font-family:inherit}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-thumb{background:#cdd6e4;border-radius:8px}.mono{font-variant-numeric:tabular-nums;font-feature-settings:"tnum"}.muted{color:var(--muted)}.right{text-align:right}.row{align-items:center;gap:10px;display:flex}.spacer{flex:1}.login-wrap{background:linear-gradient(135deg,#1b2c47,#0e1828);justify-content:center;align-items:center;padding:16px;display:flex;position:fixed;inset:0}.login-card{width:420px;max-width:94vw;box-shadow:var(--shadow-lg);background:#fff;border-radius:18px;padding:32px}.brand{align-items:center;gap:12px;display:flex}.logo{background:linear-gradient(135deg,var(--accent),#d2640a);color:#fff;border-radius:12px;flex:none;place-items:center;width:44px;height:44px;font-size:21px;display:grid;box-shadow:0 6px 16px #ea7a1766}.brand h1{letter-spacing:-.5px;font-size:21px}.brand .sub{color:var(--muted);font-size:12px}.shell{grid-template-columns:236px 1fr;min-height:100vh;display:grid}.sidebar{border-right:1px solid var(--line);background:#fff;flex-direction:column;height:100vh;padding:16px 12px;display:flex;position:sticky;top:0}.sidebar .brand{margin:6px 8px 18px}.sidebar .brand h1{font-size:16px}.nav{flex-direction:column;gap:2px;display:flex;overflow-y:auto}.nav-item{color:var(--muted);text-align:left;border-radius:9px;align-items:center;gap:11px;width:100%;padding:9px 11px;font-size:13px;font-weight:600;transition:all .1s;display:flex}.nav-item .ni{text-align:center;width:20px;font-size:15px}.nav-item:hover{background:var(--panel-2);color:var(--ink)}.nav-item.active{background:var(--accent-bg);color:var(--accent-600);box-shadow:inset 2.5px 0 0 var(--accent)}.nav-item .badge{background:var(--red);color:#fff;border-radius:10px;place-items:center;min-width:19px;height:19px;margin-left:auto;padding:0 5px;font-size:10.5px;font-weight:800;display:grid}.nav-sep{letter-spacing:.1em;text-transform:uppercase;color:var(--soft);margin:15px 11px 5px;font-size:10px;font-weight:800}.side-foot{border-top:1px solid var(--line);margin-top:auto;padding-top:12px}.user-chip{align-items:center;gap:10px;padding:6px;display:flex}.avatar{background:var(--panel-2);border-radius:9px;flex:none;place-items:center;width:34px;height:34px;font-size:16px;display:grid}.main{flex-direction:column;min-width:0;display:flex}.topbar{border-bottom:1px solid var(--line);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);z-index:9;background:#ffffffe6;align-items:center;gap:12px;padding:14px 24px;display:flex;position:sticky;top:0}.topbar h2{letter-spacing:-.3px;font-size:18px}.topbar .crumb{color:var(--muted);font-size:12px}.content{flex:1;padding:22px 24px 60px}.filter-sel,.search-in,.fld{border:1px solid var(--line);color:var(--ink);background:#fff;border-radius:9px;padding:8px 11px;font-size:13px}.search-in{width:210px}.lang-switch{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;display:inline-flex;overflow:hidden}.lang-switch button{color:var(--muted);padding:6px 12px;font-size:12px;font-weight:700}.lang-switch button.on{background:var(--accent);color:#fff}.grid{gap:14px;display:grid}.stat-grid{grid-template-columns:repeat(4,1fr)}@media (max-width:1100px){.stat-grid{grid-template-columns:repeat(2,1fr)}}.card{border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);background:#fff;padding:16px}.stat{position:relative;overflow:hidden}.stat .bar{width:4px;position:absolute;top:0;bottom:0;left:0}.stat .k{color:var(--muted);font-size:12px;font-weight:700}.stat .v{letter-spacing:-1px;margin-top:7px;font-size:26px;font-weight:800}.stat .d{color:var(--muted);margin-top:3px;font-size:11.5px}.section-h{align-items:center;gap:10px;margin:24px 2px 11px;display:flex}.section-h h3{font-size:14.5px}.pill{white-space:nowrap;border-radius:7px;align-items:center;gap:5px;padding:3px 8px;font-size:11px;font-weight:700;display:inline-flex}.pill.green{background:var(--green-bg);color:#15803d}.pill.amber{background:var(--amber-bg);color:#b45309}.pill.red{background:var(--red-bg);color:#b91c1c}.pill.grey{background:var(--grey-bg);color:#475569}.pill.blue{background:var(--blue-bg);color:#1d4ed8}.dot{border-radius:50%;width:7px;height:7px;display:inline-block}.tbl-wrap{border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);background:#fff;overflow:hidden}table{border-collapse:collapse;width:100%}th{text-align:left;letter-spacing:.04em;text-transform:uppercase;color:var(--soft);border-bottom:1px solid var(--line);background:var(--panel-2);padding:11px 15px;font-size:10.5px;font-weight:800}td{border-bottom:1px solid var(--line-2);vertical-align:middle;padding:11px 15px;font-size:13px}tr:last-child td{border-bottom:none}tbody tr:hover{background:#fafbff}.row-click{cursor:pointer}.name-cell{align-items:center;gap:10px;display:flex}.ava-sm{border-radius:8px;flex:none;place-items:center;width:32px;height:32px;font-size:12px;font-weight:700;display:grid}.sub-line{color:var(--muted);font-size:12px}.doc-mini{border:1px solid #0000;border-radius:6px;align-items:center;gap:4px;margin:2px 3px 2px 0;padding:3px 6px;font-size:11px;font-weight:700;display:inline-flex}.doc-mini.green{background:var(--green-bg);color:#15803d;border-color:#bfe6cb}.doc-mini.amber{background:var(--amber-bg);color:#b45309;border-color:#f4dcae}.doc-mini.red{background:var(--red-bg);color:#b91c1c;border-color:#f3c2c2}.btn{background:var(--accent);color:#fff;white-space:nowrap;border-radius:9px;align-items:center;gap:7px;padding:9px 14px;font-size:13px;font-weight:700;transition:all .12s;display:inline-flex}.btn:hover{background:var(--accent-600)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn.ghost{color:var(--ink);border:1px solid var(--line);background:#fff}.btn.ghost:hover{background:var(--panel-2)}.btn.sm{border-radius:8px;padding:6px 10px;font-size:12px}.btn.danger{background:var(--red)}.btn.wa{color:#063;background:#25d366}.btn.full{justify-content:center;width:100%}.field{margin-bottom:13px}.field label{color:var(--muted);margin-bottom:5px;font-size:12px;font-weight:700;display:block}.field input,.field select,.field textarea{border:1px solid var(--line);width:100%;color:var(--ink);background:#fff;border-radius:9px;padding:10px 12px;font-size:13.5px}.field-row{grid-template-columns:1fr 1fr;gap:12px;display:grid}.err{color:var(--red);margin-top:6px;font-size:12.5px}.overlay{-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:60;background:#101e3673;justify-content:center;align-items:flex-start;padding:42px 16px;display:flex;position:fixed;inset:0;overflow:auto}.modal{width:560px;max-width:96vw;box-shadow:var(--shadow-lg);background:#fff;border-radius:16px;animation:.16s pop;overflow:hidden}@keyframes pop{0%{opacity:0;transform:translateY(8px)scale(.98)}to{opacity:1;transform:none}}.modal-h{border-bottom:1px solid var(--line);align-items:center;gap:11px;padding:16px 20px;display:flex}.modal-h h3{flex:1;font-size:16px}.x{background:var(--panel-2);border-radius:8px;place-items:center;width:32px;height:32px;font-size:15px;display:grid}.modal-b{max-height:66vh;padding:18px 20px;overflow:auto}.modal-f{border-top:1px solid var(--line);justify-content:flex-end;gap:10px;padding:14px 20px;display:flex}#toast{z-index:80;flex-direction:column;gap:10px;display:flex;position:fixed;bottom:20px;right:20px}.toast{background:var(--ink);color:#fff;box-shadow:var(--shadow-lg);border-radius:11px;max-width:340px;padding:12px 16px;font-size:13px;font-weight:600;animation:.2s pop}.toast.green{background:#15803d}.toast.red{background:#b91c1c}.empty{text-align:center;color:var(--muted);padding:36px}.center{min-height:60vh;color:var(--muted);place-items:center;display:grid}.spinner{border:3px solid var(--line);border-top-color:var(--accent);border-radius:50%;width:22px;height:22px;animation:.7s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.chips{flex-wrap:wrap;gap:8px;margin-bottom:14px;display:flex}.chip{border:1px solid var(--line);color:var(--muted);background:#fff;border-radius:20px;padding:7px 13px;font-size:12.5px;font-weight:600}.chip.on{background:var(--ink);color:#fff;border-color:var(--ink)}.toggle{cursor:pointer;align-items:center;gap:9px;font-size:13px;font-weight:600;display:inline-flex}.sw-tog{background:#cdd6e4;border-radius:12px;flex:none;width:38px;height:22px;transition:all .15s;position:relative}.sw-tog:after{content:"";background:#fff;border-radius:50%;width:16px;height:16px;transition:all .15s;position:absolute;top:3px;left:3px}.toggle.on .sw-tog{background:var(--green)}.toggle.on .sw-tog:after{left:19px}.perm-grid{grid-template-columns:repeat(auto-fill,minmax(230px,1fr));gap:8px;display:grid}.perm{border:1px solid var(--line);cursor:pointer;border-radius:9px;align-items:center;gap:9px;padding:9px 11px;font-size:12.5px;display:flex}.perm.on{background:var(--accent-bg);border-color:var(--accent)}.board{border:1px solid var(--line);border-radius:var(--r);box-shadow:var(--shadow);background:#fff;overflow-x:auto}.board-inner{min-width:920px}.board-head{border-bottom:2px solid var(--line);background:var(--panel-2);display:flex;position:sticky;top:0}.board-head .lbl{width:172px;color:var(--soft);text-transform:uppercase;flex:0 0 172px;padding:10px 12px;font-size:11px;font-weight:800}.board-head .days{flex:1;grid-template-columns:repeat(7,1fr);display:grid}.board-head .day{text-align:center;border-left:1px solid var(--line);color:var(--muted);padding:8px 6px;font-size:12px;font-weight:700}.board-head .day.today{background:var(--accent-bg);color:var(--accent-600)}.board-head .day small{color:var(--soft);font-size:10px;font-weight:600;display:block}.board-row{border-bottom:1px solid var(--line-2);display:flex}.board-row:hover{background:#fafbff}.lane-label{border-right:1px solid var(--line);flex:0 0 172px;align-items:center;gap:9px;width:172px;padding:9px 12px;display:flex}.lanes{flex:1;grid-template-columns:repeat(7,1fr);min-height:56px;display:grid;position:relative}.lanes .gday{border-left:1px solid var(--line-2)}.lanes .gday.today{background:#ea7a170b}.trip-blk{color:#fff;cursor:pointer;border-radius:8px;height:40px;padding:5px 8px;font-size:11px;line-height:1.25;position:absolute;top:8px;overflow:hidden;box-shadow:0 1px 4px #0000002e}.trip-blk b{white-space:nowrap;text-overflow:ellipsis;font-weight:700;display:block;overflow:hidden}.trip-blk span{opacity:.92;font-size:10px}.lane-empty{color:var(--soft);font-size:11.5px;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.legend{color:var(--muted);flex-wrap:wrap;align-items:center;gap:16px;margin:10px 2px 0;font-size:12px;display:flex}.legend .lg{align-items:center;gap:6px;display:inline-flex}.legend .sw{border-radius:4px;width:12px;height:12px}@media (max-width:760px){.shell{grid-template-columns:1fr}.sidebar{display:none}}.doc-line{border-bottom:1px solid var(--line-2);flex-wrap:wrap;align-items:center;gap:10px;padding:9px 0;display:flex}.doc-line .di{background:var(--panel-2);border-radius:8px;flex:none;place-items:center;width:30px;height:30px;font-size:15px;display:grid}.doc-line .dn{flex-direction:column;flex:1;min-width:110px;display:flex}.doc-line .dn b{text-transform:capitalize;font-size:13px}.doc-line .dn span{color:var(--muted);font-size:11px}.doc-add{border-top:1px dashed var(--line);flex-wrap:wrap;align-items:flex-end;gap:10px;margin-top:12px;padding-top:13px;display:flex}.doc-add .field input[type=file]{padding:6px;font-size:11.5px}.det-grid{grid-template-columns:repeat(3,1fr);gap:11px 18px;margin:4px 0 6px;display:grid}@media (max-width:760px){.det-grid{grid-template-columns:repeat(2,1fr)}}.det-grid .it label{color:var(--soft);text-transform:uppercase;letter-spacing:.04em;margin-bottom:3px;font-size:10.5px;font-weight:800;display:block}.det-grid .it>div{font-size:13.5px}.back-link{color:var(--muted);align-items:center;gap:6px;margin-bottom:12px;font-size:12.5px;font-weight:600;display:inline-flex}.back-link:hover{color:var(--accent)}.detail-head{flex-wrap:wrap;align-items:center;gap:14px;display:flex}.kv{border-bottom:1px solid var(--line-2);justify-content:space-between;gap:12px;padding:7px 0;font-size:13px;display:flex}.kv:last-child{border-bottom:0}.catbar{flex-wrap:wrap;gap:7px;margin:6px 0 2px;display:flex}.catbar .c{background:var(--panel-2);border:1px solid var(--line);border-radius:9px;align-items:center;gap:7px;padding:6px 10px;font-size:12px;font-weight:600;display:inline-flex}.catbar .c b{font-variant-numeric:tabular-nums}.tabbar{border-bottom:1px solid var(--line);gap:4px;margin:18px 0 14px;display:flex}.tabbar button{color:var(--muted);border-bottom:2px solid #0000;margin-bottom:-1px;padding:9px 14px;font-size:13px;font-weight:600}.tabbar button.on{color:var(--accent);border-bottom-color:var(--accent)}.statement .stmt-head{border-bottom:2px solid var(--ink);justify-content:space-between;align-items:center;padding-bottom:12px;display:flex}.stmt-foot{color:var(--soft);text-align:center;margin-top:16px;font-size:11px}@media print{.sidebar,.topbar,.no-print{display:none!important}.shell{grid-template-columns:1fr!important}.main{height:auto!important}.content{padding:0!important}body,.main,.content{background:#fff!important}.card,.tbl-wrap{break-inside:avoid;box-shadow:none!important;border-color:#ccc!important}.stat .bar{display:none}table{font-size:11px}@page{margin:13mm}}.note-line{border-bottom:1px solid var(--line-2);align-items:flex-start;gap:10px;padding:9px 0;display:flex}.note-add{border-top:1px dashed var(--line);margin-top:12px;padding-top:12px}.fu-pill{z-index:55;background:var(--accent);color:#fff;box-shadow:var(--shadow-lg);letter-spacing:.04em;cursor:pointer;border:0;border-radius:10px 0 0 10px;padding:14px 7px;font-size:12px;font-weight:800;position:fixed;top:42%;right:0}.fu-pill:hover{background:var(--accent-600)}.fu-badge{background:var(--red);color:#fff;border:2px solid #fff;border-radius:11px;place-items:center;min-width:20px;height:20px;padding:0 5px;font-size:11px;font-weight:800;display:grid;position:absolute;top:-7px;left:-7px}.fu-overlay{-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:60;background:#101e3666;justify-content:flex-end;display:flex;position:fixed;inset:0}.fu-drawer{background:var(--bg);width:420px;max-width:94vw;height:100%;box-shadow:var(--shadow-lg);padding:16px;animation:.18s fuin;overflow:auto}@keyframes fuin{0%{opacity:.4;transform:translate(30px)}to{opacity:1;transform:none}}.fu-head{align-items:center;gap:10px;margin-bottom:14px;display:flex}.fu-head h3{font-size:16px}.fu-list{flex-direction:column;gap:10px;display:flex}.fu-item{border:1px solid var(--line);box-shadow:var(--shadow);background:#fff;border-radius:11px;padding:12px}.fu-item.done{opacity:.72}
