.m-app{--m-bg: #f3f5f9;--m-card: #fff;--m-line: #e5e9f0;--m-text: #1c2330;--m-muted: #788196;--m-brand: #1f6feb;--m-brand-d: #1559c0;min-height:100vh;background:var(--m-bg);color:var(--m-text);font-family:Sarabun,system-ui,-apple-system,Segoe UI,sans-serif;-webkit-tap-highlight-color:transparent}.m-top{position:sticky;top:0;z-index:20;display:flex;align-items:center;gap:8px;height:52px;padding:0 12px;background:var(--m-brand);color:#fff;box-shadow:0 1px 6px #0000001f}.m-top .m-title{flex:1;text-align:center;font-weight:600;font-size:17px}.m-logo{font-weight:800;letter-spacing:1px;font-size:15px}.m-back{width:32px;height:32px;border:0;background:#ffffff2e;color:#fff;border-radius:8px;font-size:22px;line-height:1;cursor:pointer}.m-main{padding:12px 12px 88px;max-width:720px;margin:0 auto}.m-nav{position:fixed;bottom:0;left:0;right:0;z-index:20;display:flex;flex-direction:row;flex-wrap:nowrap;gap:0;background:#fff;border-top:1px solid var(--m-line);padding-bottom:env(safe-area-inset-bottom,0)}.m-navbtn{flex:1;display:flex;flex-direction:column;align-items:center;gap:2px;border:0;background:none;padding:8px 0 10px;color:var(--m-muted);font-size:11px;cursor:pointer}.m-navbtn .ic{font-size:20px}.m-navbtn.on{color:var(--m-brand);font-weight:700}.m-card{background:var(--m-card);border:1px solid var(--m-line);border-radius:14px;padding:14px;margin-bottom:12px}.m-card h2{margin:0 0 10px;font-size:16px}.m-list{display:flex;flex-direction:column;gap:10px}.m-row{display:flex;align-items:center;gap:10px;background:var(--m-card);border:1px solid var(--m-line);border-radius:14px;padding:14px;cursor:pointer;text-align:left;width:100%}.m-row:active{background:#f0f4fb}.m-row .grow{flex:1;min-width:0}.m-row .t{font-weight:600;font-size:15px}.m-row .s{color:var(--m-muted);font-size:13px;margin-top:2px}.m-row .amt{font-weight:700;font-size:15px;white-space:nowrap}.m-row .chev{color:#c2c9d6;font-size:20px}.m-stats{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:12px}.m-stat{background:var(--m-card);border:1px solid var(--m-line);border-radius:14px;padding:14px}.m-stat .n{font-size:22px;font-weight:800}.m-stat .l{color:var(--m-muted);font-size:12px;margin-top:2px}.m-stat.wide{grid-column:1 / -1}.m-stat.accent{background:linear-gradient(135deg,#1f6feb,#1559c0);color:#fff}.m-stat.accent .l{color:#ffffffd9}.m-quick{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-bottom:14px}.m-qbtn{display:flex;flex-direction:column;align-items:center;gap:6px;background:var(--m-card);border:1px solid var(--m-line);border-radius:14px;padding:16px 8px;font-size:14px;font-weight:600;color:var(--m-text);cursor:pointer}.m-qbtn .ic{font-size:26px}.m-qbtn:active{background:#f0f4fb}.m-btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;width:100%;border:0;border-radius:12px;padding:14px;background:var(--m-brand);color:#fff;font-size:16px;font-weight:700;cursor:pointer}.m-btn:active{background:var(--m-brand-d)}.m-btn.ghost{background:#eef2f8;color:var(--m-text)}.m-btn.line{background:#06c755}.m-field{margin-bottom:12px}.m-field label{display:block;font-size:13px;color:var(--m-muted);margin-bottom:5px}.m-field input,.m-field textarea,.m-field select{width:100%;box-sizing:border-box;border:1px solid var(--m-line);border-radius:12px;padding:13px;font-size:16px;background:#fff;color:var(--m-text)}.m-field input:focus,.m-field textarea:focus,.m-field select:focus{outline:2px solid #bcd3fb;border-color:var(--m-brand)}.m-empty{text-align:center;color:var(--m-muted);padding:40px 0}.m-search{width:100%;box-sizing:border-box;border:1px solid var(--m-line);border-radius:12px;padding:12px 14px;font-size:16px;margin-bottom:12px}.m-badge{display:inline-block;font-size:11px;padding:2px 8px;border-radius:999px;background:#eef2f8;color:var(--m-muted)}.m-seg{display:flex;gap:6px;overflow-x:auto;margin-bottom:12px;padding-bottom:2px}.m-seg button{flex:0 0 auto;border:1px solid var(--m-line);background:#fff;border-radius:999px;padding:8px 14px;font-size:14px;color:var(--m-muted);cursor:pointer}.m-seg button.on{background:var(--m-brand);color:#fff;border-color:var(--m-brand);font-weight:700}.m-sech{font-size:13px;color:var(--m-muted);margin:4px 2px 8px}.m-sheet-bg{position:fixed;top:0;right:0;bottom:0;left:0;background:#0006;z-index:30;display:flex;align-items:flex-end}.m-sheet{background:#fff;width:100%;border-radius:18px 18px 0 0;padding:18px 16px calc(18px + env(safe-area-inset-bottom,0));max-height:88vh;overflow-y:auto}.m-sheet h3{margin:2px 0 14px;font-size:17px}.m-ro{background:#f7f9fc;border:1px dashed var(--m-line);border-radius:12px;padding:12px;font-size:14px;color:var(--m-muted);margin-bottom:12px}.m-ro strong{color:var(--m-text)}.m-grid2{display:grid;grid-template-columns:1fr 1fr;gap:10px}.m-toggle{display:flex;border:1px solid var(--m-line);border-radius:12px;overflow:hidden}.m-toggle button{flex:1;border:0;background:#fff;padding:12px 6px;font-size:14px;color:var(--m-muted);cursor:pointer}.m-toggle button.on{background:var(--m-brand);color:#fff;font-weight:700}.m-sec-h{display:flex;align-items:center;gap:8px;margin-bottom:10px}.m-sec-h .ttl{flex:1}.m-itemcard{border:1px solid var(--m-line);border-radius:12px;padding:10px;margin-bottom:10px;background:#fcfdff}.m-itemcard.opt{background:#fffdf5;border-color:#f0e3bf}.m-itemcard .no{font-size:12px;font-weight:700;color:var(--m-muted);margin-bottom:6px;display:flex;justify-content:space-between;align-items:center}.m-three{display:grid;grid-template-columns:1fr 1fr 1.2fr;gap:8px;margin-top:8px}.m-three .m-field{margin-bottom:0}.m-three label{font-size:11px}.m-three input{padding:10px;font-size:15px}.m-itemfoot{display:flex;justify-content:space-between;align-items:center;margin-top:8px;font-size:14px}.m-del{border:0;background:#fdecec;color:#d33;border-radius:8px;padding:7px 12px;font-size:13px;cursor:pointer}.m-addrow{display:flex;gap:8px;margin-top:4px}.m-addrow button{flex:1}.m-totline{display:flex;justify-content:space-between;padding:6px 0;font-size:15px}.m-totline.grand{border-top:2px solid var(--m-line);margin-top:6px;padding-top:10px;font-size:18px;font-weight:800}.m-actions{display:flex;flex-direction:column;gap:8px}.m-ok{color:#1a9e57;font-weight:700;text-align:center;padding:6px}.m-editor{background:#fff;min-height:60vh}.m-editor .page-head{flex-direction:column;align-items:flex-start;gap:8px}.m-editor .toolbar{flex-wrap:wrap}.m-editor .table{font-size:13px}.doc-wrap{background:#fff}.doc{width:210mm;min-height:297mm;margin:0 auto;padding:16mm 16mm 20mm;background:#fff;color:#1a1a1a;font-size:13px;position:relative;font-family:Sarabun,system-ui,-apple-system,Segoe UI,sans-serif}.doc-toolbar{max-width:210mm;margin:12px auto;display:flex;gap:8px;justify-content:flex-end}.doc-head{display:grid;grid-template-columns:1fr auto;column-gap:24px;row-gap:6px;align-items:end;border-bottom:2px solid var(--brand);padding-bottom:10px}.doc-head .r{text-align:right}.doc-head img{height:54px;display:block}.doc-co-name{font-weight:700;font-size:16px;color:var(--brand);margin-top:4px}.doc-co-line{font-size:11px;color:#444;line-height:1.5;max-width:110mm}.dh-title h2{margin:0;font-size:22px;color:var(--brand)}.dh-sub{font-size:12px;color:#888}.dh-meta{font-size:12px;line-height:1.5}.dh-meta strong{font-size:13px}.doc-parties{display:flex;justify-content:space-between;align-items:flex-start;margin:14px 0;gap:16px}.doc-box{flex:1}.doc-box .lbl{font-size:11px;color:#777}.doc-box .val{font-size:13px}.doc-ref-box{flex:0 0 64mm;background:#f7f9fc;border:1px solid #e6ebf2;border-radius:6px;padding:8px 11px}.doc-ref-box .val{font-size:12px;padding:1px 0}table.doc-table{width:100%;border-collapse:collapse;margin-top:8px}table.doc-table th{background:var(--brand);color:#fff;font-size:12px;padding:7px 8px;text-align:left}table.doc-table th.num,table.doc-table td.num{text-align:right}table.doc-table td{padding:7px 8px;border-bottom:1px solid #e5e5e5;vertical-align:top}.sec-row td{background:#eef4fb}.sec-row td strong{font-weight:700}.doc-desc{white-space:pre-wrap}.doc-ref{font-size:12px;margin-top:8px;color:#444}table.doc-table tr.ref-row td{color:#555}table.doc-table tr.bill-row td{font-weight:700;background:#eef4fb;border-top:2px solid var(--brand)}.opt-head td{font-weight:700;color:#9a6206;padding-top:12px}.opt-note{font-size:11px;color:#9a6206}.doc-totals{margin-top:12px;margin-left:auto;width:75mm}.doc-totals .l{display:flex;justify-content:space-between;padding:4px 0;font-size:13px}.doc-totals .grand{border-top:2px solid #1a1a1a;font-weight:700;font-size:15px;padding-top:6px}.doc-baht{text-align:right;margin-top:8px;font-weight:600;font-size:13px}.doc-terms{margin-top:16px;font-size:12px}.doc-terms .h{font-weight:700}.doc-sign{display:flex;justify-content:space-between;margin-top:30px;gap:30px}.doc-sign .col{flex:1;text-align:center}.doc-sign .sign-space{height:48px;display:flex;align-items:flex-end;justify-content:center}.doc-sign-img{max-height:48px;max-width:60mm;object-fit:contain}.doc-sign .line{border-top:1px dotted #999;margin:4px 20px 6px}.doc-sign-one{justify-content:flex-end}.doc-sign-one .col{flex:0 0 72mm}.doc-stamp{position:absolute;right:30mm;bottom:42mm;width:38mm;opacity:.9}.doc-pay-row{display:flex;justify-content:space-between;align-items:center;gap:20px;margin-top:12px}.doc-pay-row .doc-totals{margin-top:0}.doc-pay-stamp{flex:1;display:flex;align-items:center;justify-content:center}.doc-pay-stamp img{width:44mm;opacity:.9}.doc-pay-right{width:78mm;flex-shrink:0}@media print{.doc-toolbar,.sidebar{display:none!important}body{background:#fff}.doc{width:auto;min-height:auto;margin:0;padding:10mm}@page{size:A4;margin:8mm}.doc-sign,.doc-totals,.doc-pay-row,.doc-parties,table.doc-table tr{break-inside:avoid}}@font-face{font-family:Sarabun;font-style:normal;font-weight:400;font-display:swap;src:url(/fonts/Sarabun-Regular.ttf) format("truetype")}@font-face{font-family:Sarabun;font-style:normal;font-weight:600;font-display:swap;src:url(/fonts/Sarabun-SemiBold.ttf) format("truetype")}@font-face{font-family:Sarabun;font-style:normal;font-weight:700;font-display:swap;src:url(/fonts/Sarabun-Bold.ttf) format("truetype")}:root{--brand: #0a4d8c;--brand-dark: #073a6b;--accent: #2f9e44;--bg: #f4f6f9;--card: #ffffff;--ink: #1f2933;--muted: #6b7785;--line: #e3e8ef;--danger: #d6336c;--warn: #e8920c;font-family:Sarabun,Inter,system-ui,-apple-system,Segoe UI,sans-serif}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--ink);font-size:14px}h1{margin:0 0 4px;font-size:24px}h2{font-size:16px}.muted{color:var(--muted)}a{color:var(--brand)}.shell{display:flex;min-height:100vh}.sidebar{width:230px;background:var(--brand-dark);color:#e7eef7;display:flex;flex-direction:column;padding:20px 14px;position:sticky;top:0;height:100vh}.brand{display:flex;align-items:center;gap:10px;margin-bottom:26px}.brand img{height:34px;background:#fff;border-radius:6px;padding:3px 6px}.brand-name{font-weight:700;font-size:17px;line-height:1}.brand-sub{font-size:12px;opacity:.7}nav{display:flex;flex-direction:column;gap:3px}.nav-item{padding:9px 12px;border-radius:8px;cursor:pointer;color:#c7d6e6;font-size:14px;text-decoration:none;display:block}.nav-item:hover{background:#ffffff14}.nav-item.active{background:#ffffff29;color:#fff;font-weight:600}.sidebar-foot{margin-top:auto;font-size:12px;opacity:.65;word-break:break-all}.content{flex:1;padding:28px 36px;max-width:1180px}.page-head{display:flex;justify-content:space-between;align-items:flex-end;margin-bottom:16px;gap:12px;flex-wrap:wrap}.card{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:18px 22px;margin-top:14px;box-shadow:0 1px 2px #1018280a}.card h2{margin:0 0 12px}.grid-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stat{background:var(--card);border:1px solid var(--line);border-radius:12px;padding:16px 18px}.stat .n{font-size:26px;font-weight:700;color:var(--brand)}.stat .l{font-size:13px;color:var(--muted)}.btn{border:1px solid transparent;border-radius:8px;padding:8px 14px;font-size:14px;cursor:pointer;font-family:inherit;font-weight:600}.btn-sm{padding:5px 10px;font-size:13px}.btn-primary{background:var(--brand);color:#fff}.btn-primary:hover{background:var(--brand-dark)}.btn-soft{background:#eaf2fb;color:var(--brand)}.btn-ghost{background:transparent;color:var(--ink);border-color:var(--line)}.btn-ghost:hover{background:#f0f3f7}.btn-danger{background:#fff0f4;color:var(--danger);border-color:#f5c2d3}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-row{display:flex;gap:8px;flex-wrap:wrap}.field{display:flex;flex-direction:column;gap:4px;margin-bottom:12px}.field-label{font-size:13px;font-weight:600;color:#41505f}.field-hint{font-size:12px;color:var(--muted)}.input{border:1px solid var(--line);border-radius:8px;padding:8px 10px;font-size:14px;font-family:inherit;background:#fff;width:100%}.input:focus{outline:none;border-color:var(--brand)}.form-2col{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.table{width:100%;border-collapse:collapse}.table th{text-align:left;font-size:12px;color:var(--muted);font-weight:600;padding:8px 10px;border-bottom:1px solid var(--line)}.table td{padding:9px 10px;border-bottom:1px solid #eef1f5}.table tr:hover td{background:#fafbfc}.table .num{text-align:right;font-variant-numeric:tabular-nums}.row-link{cursor:pointer}.badge{font-size:12px;padding:2px 9px;border-radius:999px;font-weight:600}.badge-ok{background:#e6f6ec;color:#1f7a37}.badge-info{background:#e7f0fb;color:var(--brand)}.badge-warn{background:#fdf0d9;color:#9a6206}.badge-danger{background:#fdeaf1;color:var(--danger)}.badge-neutral{background:#eef1f5;color:#5a6776}.tabs{display:flex;gap:4px;border-bottom:1px solid var(--line);margin:16px 0}.tab{padding:9px 16px;cursor:pointer;border-bottom:2px solid transparent;color:var(--muted);font-weight:600}.tab.active{color:var(--brand);border-bottom-color:var(--brand)}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#10182873;display:grid;place-items:center;z-index:50;padding:20px}.modal{background:#fff;border-radius:14px;width:520px;max-width:100%;max-height:90vh;overflow:auto}.modal-wide{width:920px}.modal-head{display:flex;justify-content:space-between;align-items:center;padding:16px 22px;border-bottom:1px solid var(--line);position:sticky;top:0;background:#fff}.modal-head h3{margin:0;font-size:17px}.modal-x{border:none;background:none;font-size:18px;cursor:pointer;color:var(--muted)}.modal-body{padding:20px 22px}.empty{text-align:center;color:var(--muted);padding:36px}.err{color:var(--danger)}.ok{color:var(--accent)}.toolbar{display:flex;gap:8px;align-items:center;flex-wrap:wrap}.spacer{flex:1}.totals{margin-left:auto;width:320px}.totals .line{display:flex;justify-content:space-between;padding:4px 0}.totals .grand{font-size:18px;font-weight:700;border-top:2px solid var(--ink);margin-top:6px;padding-top:8px}.inline-sm{font-size:12px;color:var(--muted)}.calc-row{display:flex;justify-content:space-between;padding:3px 0;font-size:13px}.calc-row.total{font-weight:700;border-top:1px solid var(--line);margin-top:4px;padding-top:6px}.pill-toggle{display:inline-flex;border:1px solid var(--line);border-radius:8px;overflow:hidden}.pill-toggle button{border:none;background:#fff;padding:6px 12px;cursor:pointer;font-size:13px;font-family:inherit}.pill-toggle button.on{background:var(--brand);color:#fff}.tag-input{display:flex;gap:8px;align-items:center}.grid-2{display:grid;grid-template-columns:1fr 1fr;gap:0 16px}.input-sm{padding:5px 7px;font-size:13px}.table-compact th,.table-compact td{padding:6px 7px;font-size:13px}.table-compact td{vertical-align:top}.callout-warn{background:#fff7e6;border:1px solid #ffe1a8;color:#8a5a00;border-radius:8px;padding:10px 12px;font-size:13px;margin-bottom:12px}@media(max-width:720px){.grid-2{grid-template-columns:1fr}}@media(max-width:720px){.grid-stats{grid-template-columns:repeat(2,1fr)}.form-2col{grid-template-columns:1fr}.sidebar{width:64px}.brand-name,.brand-sub,.nav-item span,.sidebar-foot{display:none}.content{padding:18px}}
