@import"https://fonts.googleapis.com/css2?family=Sarabun:wght@400;500;600;700;800&display=swap";:root{--lime:#7FD858;--green:#3C8A1E;--ink:#16261A;--paper:#F5F8F1;--line:#E5EAE0;--muted:#7F8C82;--danger:#A53F36;--surface:#fff}*{box-sizing:border-box}body{margin:0;font-family:Sarabun,system-ui,-apple-system,sans-serif;background:var(--paper);color:#1d2b22}button{font-family:inherit;cursor:pointer}input,select,textarea{font-family:inherit;font-size:14px;width:100%;padding:9px 11px;border:1px solid var(--line);border-radius:9px;background:#fff}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--lime);box-shadow:0 0 0 3px #7fd85833}fieldset{border:0;padding:0;margin:0;min-width:0}.screen{min-height:100vh;display:flex}.center{align-items:center;justify-content:center}.spin{width:34px;height:34px;border:3px solid #d9e6d2;border-top-color:var(--green);border-radius:50%;animation:sp .9s linear infinite;margin:30px auto}@keyframes sp{to{transform:rotate(360deg)}}.btn-primary{background:var(--lime);color:#16280c;border:0;border-radius:10px;padding:10px 16px;font-weight:700}.btn-primary.big{width:100%;padding:13px;font-size:15px;margin-top:6px}.btn-primary:disabled{opacity:.6}.btn-ghost{background:#fff;border:1px solid var(--line);border-radius:10px;padding:9px 14px;color:#34493b}.btn-ghost.sm{padding:6px 10px;font-size:12px}.btn-danger{background:var(--danger);color:#fff;border:0;border-radius:9px;padding:8px 14px;margin-right:8px}.btn-danger-ghost{background:#fff;border:1px solid #e7c9c5;color:var(--danger);border-radius:9px;padding:8px 14px}.err{background:#fbedeb;color:var(--danger);border:1px solid #f0d7d3;border-radius:9px;padding:10px 13px;margin:10px 0;font-size:13.5px}.info{background:#eaf4e4;color:#2e6b17;border:1px solid #d3e8c8;border-radius:9px;padding:10px 13px;margin:10px 0;font-size:13.5px}.muted{color:var(--muted)}.auth-bg{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(160deg,#eef6e8,#f5f8f1);padding:20px}.auth-card{background:#fff;border:1px solid var(--line);border-radius:18px;padding:30px;width:min(420px,94vw);box-shadow:0 24px 60px -28px #00000059}.auth-logo{text-align:center;margin-bottom:18px}.auth-logo-img{display:block;width:200px;max-width:72%;height:auto;margin:0 auto 4px}.auth-logo h1{margin:6px 0 2px;color:var(--green);letter-spacing:1px;font-size:22px}.brandmark{display:inline-grid;place-items:center;width:54px;height:54px;border-radius:14px;background:var(--lime);color:#16280c;font-weight:800}.seg{display:flex;background:#eef1ec;border-radius:11px;padding:4px;margin-bottom:14px}.seg button{flex:1;border:0;background:transparent;padding:9px;border-radius:8px;color:#5a6a5f;font-weight:600}.seg button.on{background:#fff;color:var(--ink);box-shadow:0 1px 4px #00000014}.field{display:block;margin-bottom:12px}.field span{display:block;font-size:12.5px;color:#5a6a5f;margin-bottom:4px}.app{display:flex;min-height:100vh}.rail{width:220px;background:var(--ink);color:#cfe3c4;display:flex;flex-direction:column;padding:18px 14px;position:sticky;top:0;height:100vh}.rail-brand{font-weight:800;font-size:20px;color:#fff;letter-spacing:1px;margin-bottom:20px}.rail-brand small{color:var(--lime);font-weight:600}.rail-foot-logo{display:block;width:88px;height:auto;margin:0 auto 12px}.rail nav{display:flex;flex-direction:column;gap:4px}.navbtn{background:transparent;border:0;color:#bcd3b0;text-align:left;padding:10px 12px;border-radius:9px;font-size:14px}.navbtn:hover{background:#ffffff0f}.navbtn.on{background:var(--lime);color:#16280c;font-weight:700}.rail-foot{margin-top:auto;border-top:1px solid rgba(255,255,255,.1);padding-top:12px}.who{font-size:13px;margin-bottom:8px;color:#fff}.rolechip{display:inline-block;margin-top:4px;font-size:11px;background:#7fd85833;color:var(--lime);padding:2px 8px;border-radius:6px}.main{flex:1;min-width:0}.page{max-width:1040px;margin:0 auto;padding:26px 28px}.page-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:10px}.page-head h2{margin:0;font-size:20px;color:var(--ink)}.head-actions{display:flex;gap:8px;flex-wrap:wrap}.yearbar{display:flex;align-items:center;gap:10px;background:var(--ink);color:#fff;border-radius:11px;padding:10px 16px;margin-bottom:16px}.yearbar select{width:auto;background:#ffffff1a;color:#fff;border-color:#fff3}.yearbar select option{color:var(--ink)}.stat-big{font-size:17px;margin-bottom:14px}.cards{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:12px}.statcard{background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px;text-align:left}.statnum{font-size:26px;font-weight:800;color:var(--green)}.statlbl{font-size:13px;color:#5a6a5f;margin-top:2px}.toolbar{display:flex;gap:10px;margin-bottom:14px;flex-wrap:wrap}.toolbar select{width:auto}.toolbar input{flex:1;min-width:200px}.grid{width:100%;border-collapse:collapse;background:#fff;border:1px solid var(--line);border-radius:12px;overflow:hidden}.grid th{background:#f0f4ec;text-align:left;padding:11px 13px;font-size:12.5px;color:#5a6a5f}.grid td{padding:11px 13px;border-top:1px solid var(--line);font-size:14px;vertical-align:top}.rowlink{cursor:pointer}.rowlink:hover{background:#f7faf4}.sub{font-size:12px;color:var(--muted)}.empty{text-align:center;color:var(--muted);padding:24px}.pager{display:flex;align-items:center;justify-content:center;gap:14px;margin-top:14px;font-size:13px;color:#5a6a5f}.pager button{background:#fff;border:1px solid var(--line);border-radius:8px;padding:7px 12px}.pager button:disabled{opacity:.5}.pill{display:inline-block;font-size:11.5px;padding:3px 9px;border-radius:7px;background:#eef1ec;color:#41523f;font-weight:600}.pill.done,.pill.DELETE{background:#e7f4e1;color:#2e6b17}.pill.printed,.pill.UPDATE{background:#fff3df;color:#9a6a12}.pill.INSERT{background:#e6eef7;color:#2e5c8a}.formgrid{display:grid;grid-template-columns:1fr 1fr;gap:13px;background:#fff;border:1px solid var(--line);border-radius:13px;padding:18px;margin-bottom:14px}.cell{display:flex;flex-direction:column}.cell span{font-size:12.5px;color:#5a6a5f;margin-bottom:4px}.cell.full{grid-column:1/-1}.roundinfo{justify-content:center;background:#eef7e8;border:1px solid var(--lime);border-radius:10px;padding:8px 12px;font-size:12.5px}.chk{display:flex;align-items:center;gap:8px;font-size:13.5px}.chk input{width:auto}.creds{background:#fff7ef;border:1px solid #f0dcc0;border-radius:13px;padding:14px 18px;margin-bottom:14px}.creds legend{font-size:13px;color:#9a6a12;font-weight:700;padding:0 6px}.danger{margin-top:10px}.loglist{display:flex;flex-direction:column;gap:8px}.logrow{background:#fff;border:1px solid var(--line);border-radius:11px;padding:11px 14px;font-size:13.5px;display:flex;flex-wrap:wrap;gap:8px;align-items:center}.diff{flex-basis:100%;font-size:12px;color:#5a6a5f;background:#f7faf4;border-radius:8px;padding:6px 10px;margin-top:4px}.diff code{background:#eef1ec;padding:1px 5px;border-radius:4px}@media (max-width:720px){.rail{position:fixed;bottom:0;left:0;right:0;top:auto;width:100%;height:auto;flex-direction:row;align-items:center;z-index:20;padding:8px}.rail-brand,.rail-foot{display:none}.rail nav{flex-direction:row;gap:4px;overflow:auto}.main{padding-bottom:70px}.formgrid{grid-template-columns:1fr}}.letter-panel{display:flex;justify-content:space-between;align-items:center;gap:16px;flex-wrap:wrap;background:#fff;border:1px solid var(--lime);border-radius:13px;padding:16px 18px;margin-bottom:14px;box-shadow:0 0 0 3px #7fd8581f}.letter-panel h3{margin:0 0 3px;font-size:15px;color:var(--ink)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#16261a8c;display:flex;align-items:center;justify-content:center;z-index:80;padding:20px}.modal{background:#fff;border-radius:16px;width:min(840px,96vw);max-height:92vh;display:flex;flex-direction:column;overflow:hidden;box-shadow:0 30px 80px -20px #00000080}.modal-head{display:flex;align-items:center;gap:12px;padding:15px 20px;border-bottom:1px solid var(--line);font-size:14px}.modal-x{margin-left:auto;background:none;border:0;font-size:18px;color:var(--muted);padding:4px 8px;border-radius:8px}.modal-warn{background:#fff3df;color:#9a6a12;font-size:12.5px;padding:9px 20px;border-bottom:1px solid var(--line)}.modal-body{overflow:auto;padding:22px;background:#eef0ea}.letter-edit{background:#fff;max-width:720px;margin:0 auto;padding:46px 54px;box-shadow:0 2px 10px #0000001f;font-size:14px;line-height:1.55;color:#1a1a1a;outline:none;min-height:300px}.letter-edit:focus{box-shadow:0 0 0 2px var(--lime),0 2px 10px #0000001f}.letter-edit h1{font-size:18px;text-align:center;letter-spacing:1px;margin:16px 0}.letter-edit h2{font-size:15px;margin:16px 0 4px;border-bottom:1px solid #bbb;padding-bottom:2px}.letter-edit p{margin:6px 0}.letter-edit ul{margin:4px 0 4px 20px}.letter-edit .right{text-align:right}.letter-edit table.sig-t{width:100%;margin-top:26px}.letter-edit td{vertical-align:top;width:50%}.modal-foot{display:flex;align-items:center;gap:10px;padding:13px 20px;border-top:1px solid var(--line)}.panel{background:#fff;border:1px solid var(--line);border-radius:13px;padding:16px 18px;margin-top:16px}.panel h3{margin:0 0 10px;font-size:15px;color:var(--ink)}.bars{display:flex;flex-direction:column;gap:6px}.bar-row{display:flex;align-items:center;gap:10px;background:transparent;border:0;border-radius:8px;padding:6px 8px;text-align:left;width:100%}.bar-row:hover{background:#f3f7ef}.bar-name{flex:0 0 200px;font-size:13px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bar-track{flex:1;height:10px;background:#eef1ec;border-radius:6px;overflow:hidden}.bar-fill{display:block;height:100%;background:var(--lime)}.bar-num{flex:0 0 36px;text-align:right;font-weight:700;color:var(--green)}.nextbtn{background:#eef7e8;border:1px solid var(--lime);color:var(--green);border-radius:8px;width:30px;height:30px;font-weight:800}.nextbtn:hover{background:var(--lime);color:#16280c}.grid td.mono{font-family:ui-monospace,SFMono-Regular,Courier New,monospace;font-size:12.5px;color:#41523f;white-space:nowrap}.grid th.sortth{cursor:pointer;-webkit-user-select:none;user-select:none;white-space:nowrap}.grid th.sortth:hover{background:#e6efdf;color:var(--green)}.agent-row{display:flex;gap:6px;align-items:center}.agent-row select,.agent-row input{flex:1;min-width:0}.btn-primary.sm{padding:7px 12px;font-size:13px}.be-hint{display:block;font-size:11.5px;color:var(--green);margin-top:3px;font-weight:600}.filterrow th{background:#f6f9f3;padding:5px 8px;border-top:1px solid var(--line)}.colf{width:100%;padding:5px 7px;font-size:12.5px;border-radius:7px}.pgsize{display:inline-flex;align-items:center;gap:6px}.pgsize select{width:auto;padding:5px 8px;font-size:13px}.colpick{position:relative;display:inline-block}.colpick-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;z-index:20}.colpick-menu{position:absolute;z-index:30;top:calc(100% + 4px);right:0;background:#fff;border:1px solid var(--line);border-radius:10px;box-shadow:0 8px 24px #00000024;padding:6px;min-width:190px;max-height:340px;overflow:auto}.colpick-item{display:flex;align-items:center;gap:9px;padding:7px 9px;border-radius:7px;cursor:pointer;font-size:14px;white-space:nowrap}.colpick-item:hover{background:#f1f6ec}.colpick-item input{width:auto;margin:0}
