@import "https://fonts.googleapis.com/css2?family=Noto+Sans+Thai:wght@300;400;500;600;700&family=DM+Mono:wght@400;500&display=swap";
:root{--bg:#f0f2f5;--s1:#fff;--s2:#f8fafc;--s3:#e8ecf1;--hv:#eef4ff;--bd:#d4dbe6;--t1:#0f172a;--t2:#475569;--t3:#94a3b8;--bl:#1e40af;--bl2:#1e3a8a;--blA:#1e40af0f;--blL:#dbeafe;--gn:#059669;--gnL:#d1fae5;--or:#d97706;--orA:#d977060f;--rd:#dc2626;--pp:#7c3aed;--f:"Noto Sans Thai",sans-serif;--m:"DM Mono",monospace;--r:6px;--acc:#3b82f6;--acc2:#2563eb}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--f);background:var(--bg);color:var(--t1);-webkit-font-smoothing:antialiased;height:100vh;font-size:12px;overflow:hidden}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:0 0}::-webkit-scrollbar-thumb{background:#c1c9d4;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#94a3b8}.top{background:#fff;border-bottom:1px solid #e2e8f0;align-items:center;height:48px;padding:0 12px;display:flex;box-shadow:0 1px 4px #0000000a}.top-l{cursor:pointer;align-items:center;gap:6px;display:flex}.top-l:hover .logo-box{transform:scale(1.05)}.logo-box{background:linear-gradient(135deg,#3b82f6,#1e40af);border-radius:8px;justify-content:center;align-items:center;width:28px;height:28px;transition:transform .15s;display:flex;box-shadow:0 2px 8px #3b82f640}.top-l h1{font:700 14px var(--f);color:#1e293b;letter-spacing:-.3px}.ver{font:600 8px var(--m);color:#3b82f6;background:#eff6ff;border-radius:10px;padding:2px 6px}.top-r{align-items:center;gap:6px;display:flex}.top-sep{background:#e2e8f0;width:1px;height:24px;margin:0 2px}.top-file{font:400 10px var(--m);color:#64748b;text-align:center;text-overflow:ellipsis;white-space:nowrap;flex:1;padding:0 12px;overflow:hidden}.b{font:600 10px var(--f);border:1px solid var(--bd);border-radius:var(--r);background:var(--s1);color:var(--t1);cursor:pointer;white-space:nowrap;align-items:center;gap:4px;padding:4px 10px;transition:all .15s;display:inline-flex;box-shadow:0 1px 2px #0000000a}.b:hover{background:var(--hv);border-color:var(--acc);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f626}.bp{background:linear-gradient(135deg,var(--acc),var(--acc2));border-color:var(--acc2);color:#fff;box-shadow:0 2px 8px #2563eb4d}.bp:hover{background:linear-gradient(135deg,var(--acc2),#1d4ed8);box-shadow:0 3px 12px #2563eb66}.bg{color:#fff;background:linear-gradient(135deg,#059669,#047857);border-color:#047857;box-shadow:0 2px 8px #0596694d}.wrap{height:calc(100vh - 44px);display:flex}.L{flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.D{background:var(--s3);cursor:col-resize;flex-shrink:0;width:3px;transition:background .15s}.D:hover,.D.on{background:var(--acc)}.R{background:var(--s1);border-left:1px solid var(--bd);flex-direction:column;width:620px;min-width:300px;max-width:1200px;display:flex}.wrap .tbar{display:none}.vtb{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border:1px solid #00000014;border-radius:12px;flex-direction:column;gap:2px;padding:5px;display:flex;position:absolute;top:56px;left:8px;box-shadow:0 4px 16px #00000014}.vt{width:30px;height:30px;color:var(--t2);cursor:pointer;background:0;border:none;border-radius:8px;justify-content:center;align-items:center;font-size:13px;transition:all .15s;display:flex;position:relative}.vt:hover{background:var(--hv);color:var(--acc);transform:scale(1.05)}.vt.on{background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;box-shadow:0 2px 8px #3b82f64d}.hvb{z-index:100;-webkit-backdrop-filter:blur(12px);backdrop-filter:blur(12px);background:#fffffff2;border:1px solid #00000014;border-radius:10px;gap:2px;padding:4px;display:flex;position:absolute;top:8px;left:50%;transform:translate(-50%);box-shadow:0 4px 16px #00000014}.hv{width:34px;height:30px;color:var(--t2);cursor:pointer;background:0;border:none;border-radius:7px;justify-content:center;align-items:center;transition:all .15s;display:flex;position:relative}.hv:hover{background:var(--hv);color:var(--acc);transform:scale(1.08)}.hv:active{transform:scale(.95)}.hv.on{background:linear-gradient(135deg,var(--acc),var(--acc2));color:#fff;box-shadow:0 2px 6px #3b82f64d}.hv:after{content:attr(data-tip);color:#fff;font:600 9px var(--f);white-space:nowrap;opacity:0;pointer-events:none;z-index:200;background:#1e293b;border-radius:5px;padding:4px 8px;transition:all .15s;position:absolute;top:40px;left:50%;transform:translate(-50%);box-shadow:0 4px 12px #0003}.hv:hover:after{opacity:1}.hvs{background:var(--bd);flex-shrink:0;width:1px;margin:2px 1px}.vt:after{content:attr(data-tip);color:#fff;font:600 10px var(--f);white-space:nowrap;opacity:0;pointer-events:none;z-index:200;background:#1e293b;border-radius:6px;padding:4px 10px;transition:all .15s;position:absolute;top:50%;left:42px;transform:translateY(-50%);box-shadow:0 4px 12px #0003}.vt:hover:after{opacity:1}.vts{background:var(--s3);width:24px;height:1px;margin:2px auto}#cv{background:linear-gradient(#f1f5f9,#e2e8f0);flex:1;position:relative;overflow:hidden}.ci{font:9px var(--m);pointer-events:none;color:var(--t3);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#fffffff2;border:1px solid #0000000f;border-radius:4px;padding:3px 8px;position:absolute}.cb{align-items:center;gap:4px;display:flex;top:8px;left:8px}.cb .dot{background:#22c55e;border-radius:50%;width:6px;height:6px;box-shadow:0 0 6px #22c55e80}.cs{bottom:8px;left:8px}.wel{z-index:200;text-align:center;background:linear-gradient(135deg,#eef2ff 0%,#e0e7ff 30%,#dbeafe 60%,#f0fdfa 100%);justify-content:center;align-items:center;display:flex;position:absolute;inset:0;overflow:hidden}.wel.off{display:none}.wel:before{content:"";background:radial-gradient(circle,#3b82f614 0%,#0000 70%);border-radius:50%;width:500px;height:500px;position:absolute;top:-20%;right:-10%}.wel:after{content:"";background:radial-gradient(circle,#7c3aed0f 0%,#0000 70%);border-radius:50%;width:400px;height:400px;position:absolute;bottom:-15%;left:-5%}.wel-card{z-index:1;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);background:#ffffffd9;border:1px solid #fff9;border-radius:20px;width:100%;max-width:480px;padding:32px 28px 24px;position:relative;box-shadow:0 8px 40px #1e40af14,0 1px 3px #0000000f}.wel-logo{background:linear-gradient(135deg,#3b82f6,#1e40af);border-radius:16px;justify-content:center;align-items:center;width:56px;height:56px;margin:0 auto 12px;display:flex;box-shadow:0 4px 16px #3b82f64d}.wel-btn{font:600 11px var(--f);cursor:pointer;border:none;border-radius:10px;align-items:center;gap:6px;padding:10px 20px;transition:all .2s;display:inline-flex}.wel-btn-primary{color:#fff;background:linear-gradient(135deg,#3b82f6,#1e40af);box-shadow:0 4px 12px #3b82f64d}.wel-btn-primary:hover{transform:translateY(-1px);box-shadow:0 6px 20px #3b82f666}.wel-btn-secondary{color:#1e40af;background:#fff;border:1px solid #bfdbfe;box-shadow:0 2px 8px #0000000a}.wel-btn-secondary:hover{background:#eff6ff;border-color:#93c5fd}.wel-proj{text-align:left;background:#fff;border:1px solid #e2e8f0;border-radius:14px;margin-top:16px;overflow:hidden;box-shadow:0 2px 8px #00000008}.wel-proj-hdr{font:600 11px var(--f);color:#1e40af;background:linear-gradient(135deg,#f8fafc,#f1f5f9);border-bottom:1px solid #e2e8f0;align-items:center;gap:6px;padding:10px 14px;display:flex}.wel-proj-item{cursor:pointer;border-bottom:1px solid #f1f5f9;align-items:center;gap:10px;padding:10px 14px;transition:background .15s;display:flex}.wel-proj-item:hover{background:#eff6ff}.wel-proj-item:last-child{border-bottom:none}.wel-proj-icon{border-radius:10px;flex-shrink:0;justify-content:center;align-items:center;width:36px;height:36px;font-size:16px;display:flex}.wel-proj-name{font:600 11px var(--f);color:#1e293b;text-overflow:ellipsis;white-space:nowrap;overflow:hidden}.wel-proj-meta{font:400 9px var(--m);color:#94a3b8;margin-top:1px}.wel-drop{color:#94a3b8;font:9px var(--f);cursor:pointer;border:2px dashed #cbd5e1;border-radius:12px;margin-top:14px;padding:12px;transition:all .2s}.wel-drop:hover{color:#3b82f6;background:#3b82f608;border-color:#3b82f6}.wel h2{color:var(--bl);margin:8px 0 4px;font-size:16px;font-weight:700}.wel p{color:var(--t2);margin-bottom:12px;font-size:10px}.rh{border-bottom:1px solid var(--bd);background:linear-gradient(180deg,var(--s1),var(--s2));flex-wrap:nowrap;align-items:center;gap:3px;height:auto;min-height:32px;padding:2px 6px;display:flex;overflow:auto hidden}.rh h2{color:var(--bl);white-space:nowrap;align-items:center;gap:4px;margin-right:4px;font-size:11px;font-weight:700;display:flex}.badge{font:700 9px var(--m);color:var(--bl);background:linear-gradient(135deg,#dbeafe,#bfdbfe);border-radius:10px;padding:2px 8px}.pi{border-bottom:1px solid var(--bd);background:var(--s2);padding:6px 10px;font-size:10px;line-height:1.5;display:none}.pi.show{display:block}.pi b{color:var(--bl)}.tabs{border:0;border-bottom:1px solid var(--bd);background:linear-gradient(#f8fafc,#f1f5f9);flex-wrap:nowrap;flex-shrink:0;gap:2px;padding:0 4px;display:flex;overflow-x:auto}.tab{font:600 11px var(--f);color:var(--t3);cursor:pointer;white-space:nowrap;letter-spacing:-.1px;background:0;border:none;border-bottom:3px solid #0000;flex-shrink:0;padding:8px 14px;transition:all .15s}.tab:hover{color:var(--t1);background:#3b82f60a}.tab.on{color:var(--acc2);border-bottom-color:var(--acc2);background:#3b82f60f}.sbar{border-bottom:1px solid var(--bd);background:var(--s2);padding:4px 8px}.si{width:100%;font:10px var(--f);border:1px solid var(--bd);background:var(--s1);color:var(--t1);border-radius:6px;outline:0;padding:5px 8px 5px 24px;transition:all .15s}.si:focus{border-color:var(--acc);box-shadow:0 0 0 3px #3b82f61a}.sw{position:relative}.sw:before{content:"🔍";font-size:9px;position:absolute;top:50%;left:6px;transform:translateY(-50%)}.tw{background:var(--s1);flex:1;overflow:auto}table{border-collapse:collapse;width:100%}thead{z-index:10;position:sticky;top:0}th{font:600 8px var(--f);text-align:center;color:#e0ecff;text-transform:uppercase;letter-spacing:.3px;white-space:nowrap;background:linear-gradient(#1e3a8a,#1e40af);border:1px solid #2a4ba5;padding:5px 6px}td{border-bottom:1px solid var(--s3);padding:3px 5px;font-size:10px}.r{text-align:right;font-family:var(--m);color:#1e293b;font-size:10px;font-weight:500}.c{text-align:center}tr{transition:background 80ms}tr:nth-child(2n){background:#f8fafc}tr:hover{background:#eef4ff}tr.sel{border-left:4px solid #f59e0b;outline:none;animation:.6s ease-out selPulse;background:#f59e0b33!important}tr.sel td{color:#92400e!important;font-weight:600!important}@keyframes selPulse{0%{background:#f59e0b73!important}to{background:#f59e0b33!important}}tr.hl{border-left:3px solid #3b82f6;outline:none;background:#3b82f624!important}tr.hl td{color:#1e40af!important;font-weight:500!important}tr.item.linked{cursor:pointer}tr.item.linked:hover{background:#3b82f614!important}tr.L1{cursor:pointer;background:linear-gradient(135deg,#1e3a8a,#2563eb)!important}tr.L1 td{color:#fff;text-shadow:0 1px 2px #0000004d;border-bottom:none;padding:6px 8px;font-size:11px;font-weight:700}.eye-btn{float:right;cursor:pointer;opacity:.5;-webkit-user-select:none;user-select:none;border-radius:3px;padding:0 3px;font-size:11px;transition:opacity .15s,background .15s}.eye-btn:hover{opacity:1;background:#fff3}.eye-btn.off{opacity:.3}.eye-col{cursor:pointer;opacity:.5;text-align:center;-webkit-user-select:none;user-select:none;vertical-align:middle;border-radius:2px;width:16px;font-size:9px;display:inline-block}.eye-col:hover{opacity:1;background:#0000000f}.eye-col.off{opacity:.25}tr.vis-off{opacity:.4}tr.vis-off td{-webkit-text-decoration:line-through #fff6;text-decoration:line-through #fff6}tr.item.vis-off{opacity:.35}tr.item.vis-off td{-webkit-text-decoration:line-through #00000026;text-decoration:line-through #00000026}tr.L1 td.r{color:#fff;text-shadow:0 1px 3px #0006;font-size:12px;font-weight:800}tr.L1:hover{background:linear-gradient(135deg,#1e40af,#3b82f6)!important}tr.L2{cursor:pointer;background:linear-gradient(135deg,#dbeafe,#eff6ff)!important}tr.L2 td{color:#1e3a8a;border-bottom:1px solid #bfdbfe;padding:4px 8px;font-size:10px;font-weight:600}tr.L2 td.r{color:#1e3a8a;font-size:11px;font-weight:700}tr.sub{background:var(--s2)!important}tr.sub td{border-top:2px solid var(--bd);font-size:9.5px;font-weight:700}tr.gt{background:linear-gradient(135deg,#1e3a8a,#2563eb)!important}tr.gt td{color:#fef08a;text-shadow:0 1px 3px #0000004d;padding:6px 8px;font-size:11px;font-weight:800}.arr{margin-right:4px;font-size:9px;transition:transform .2s;display:inline-block}.arr.closed{transform:rotate(-90deg)}.pnl{background:var(--bg);flex-direction:column;flex:1;min-height:0;padding:0;display:none;overflow:hidden}.pnl.on{display:flex}.card{background:var(--s1);border:1px solid var(--bd);border-radius:8px;margin-bottom:6px;overflow:hidden}.card-h{background:var(--blL);cursor:pointer;color:var(--bl);justify-content:space-between;align-items:center;padding:6px 10px;font-size:11px;font-weight:600;display:flex}.card-h:hover{background:#c7dbfa}.card-b{padding:8px 10px}.db-bar{border-bottom:1px solid var(--bd);background:var(--s2);flex-wrap:wrap;align-items:center;gap:3px;padding:4px 8px;display:flex}.db-cnt{font:600 9px var(--m);color:var(--bl);margin-left:auto}table.db{-webkit-user-select:none;user-select:none;width:100%}table.db th{background:var(--blL);color:var(--bl);z-index:2;cursor:pointer;white-space:nowrap;position:sticky;top:0}table.db th:hover{background:#c7dbfa}table.db td{border:1px solid var(--s3);padding:1px 3px;font-size:9px}table.db tr{transition:background .15s}table.db tr:hover{background:#2563eb0a}table.db tr.db-sel{border-left:4px solid #f59e0b;animation:.6s ease-out selPulse;background:#f59e0b2e!important}table.db tr.db-sel td{color:#92400e!important;font-weight:500!important}table.db tr.db-drag-over{border-top:2px solid var(--bl)}table.db input{width:100%;font:9px var(--f);color:var(--t1);box-sizing:border-box;background:0 0;border:1px solid #0000;border-radius:2px;padding:1px 3px}table.db input:focus{border-color:var(--bl);background:var(--s1);outline:0}table.db input.num{text-align:right;font-family:var(--m)}table.db select{font:9px var(--f);color:var(--t1);background:0 0;border:1px solid #0000;border-radius:2px;width:100%;padding:1px 2px}table.db select:focus{border-color:var(--bl);outline:0}tr.db-new td{background:var(--gnL)}.db-filter-pop{background:var(--s1);border:1px solid var(--bd);z-index:900;border-radius:6px;min-width:180px;max-height:260px;padding:8px;font-size:9px;position:fixed;overflow-y:auto;box-shadow:0 4px 16px #00000026}.db-filter-pop label{cursor:pointer;border-radius:3px;padding:2px 4px;display:block}.db-filter-pop label:hover{background:var(--blL)}.db-filter-pop input[type=checkbox]{margin-right:4px}.db-filter-pop .fp-search{width:100%;font:9px var(--f);border:1px solid var(--bd);border-radius:4px;margin-bottom:4px;padding:3px 6px}.db-filter-pop .fp-acts{gap:4px;margin-bottom:4px;font-size:8px;display:flex}.db-filter-pop .fp-acts a{color:var(--bl);cursor:pointer;text-decoration:underline}.db-ctx{background:var(--s1);border:1px solid var(--bd);z-index:900;border-radius:6px;min-width:160px;padding:4px;font-size:10px;position:fixed;box-shadow:0 4px 12px #00000026}.db-ctx div{cursor:pointer;border-radius:4px;align-items:center;gap:6px;padding:5px 10px;display:flex}.db-ctx div:hover{background:var(--blL)}.db-ctx .sep{border-top:1px solid var(--s3);cursor:default;margin:2px 0;padding:0}.db-ctx .sep:hover{background:0 0}table.db td.db-cell-sel{outline-offset:-1px;z-index:1;outline:2px solid #2563eb;position:relative;background:#2563eb0f!important}table.db td.db-cell-range{background:#2563eb14!important}.db-fill-handle{cursor:crosshair;z-index:3;background:#2563eb;border:1px solid #fff;width:7px;height:7px;position:absolute;bottom:-3px;right:-3px}table.db td.db-fill-preview{background:#2563eb26!important}#dbSubPanel table.db th{color:var(--pp);background:linear-gradient(135deg,#7c3aed1f,#2563eb14)}#dbSubPanel table.db tr:hover{background:#7c3aed0f}#dbSubPanel table.db tr.db-sub-hl{border-left:3px solid var(--pp);background:#7c3aed1a!important}table.db input.fx-mode{color:var(--pp)!important;background:#7c3aed0d!important;font-weight:600!important}table.db input.fx-editing{color:var(--bl)!important;background:var(--s1)!important;border-color:var(--pp)!important;font-weight:400!important}.fx-badge{font:600 6px var(--m);color:var(--pp);pointer-events:none;position:absolute;top:-1px;right:2px}table.db td.fx-cell{position:relative}.cmp-tbl{border-collapse:collapse;width:100%;font-size:9px}.cmp-tbl thead{z-index:5;position:sticky;top:0}.cmp-tbl th{color:var(--bl);white-space:nowrap;background:#dbeafe;border:1px solid #bfdbfe;padding:5px 6px;font-size:8px}.cmp-tbl td{border:1px solid var(--s3);padding:3px 6px}.cmp-tbl tr:hover{background:var(--blA)}.cmp-tbl .grp{background:var(--blL);color:var(--bl);font-size:10px;font-weight:600}.cmp-up{color:var(--rd);font-weight:600}.cmp-dn{color:var(--gn);font-weight:600}.cmp-new{background:#22c55e0f}.cmp-del{color:var(--t3);background:#dc26260f;text-decoration:line-through}.cmp-diff{background:#f59e0b0f}.cc-item{border-bottom:1px solid var(--s3);align-items:center;gap:4px;padding:3px 0;font-size:9px;display:flex}.cc-item input{font:9px var(--f);border:1px solid var(--bd);background:var(--s1);border-radius:3px;flex:1;padding:2px 4px}.cc-item .del{background:var(--rd);color:#fff;cursor:pointer;border:none;border-radius:3px;justify-content:center;align-items:center;width:18px;height:18px;font-size:10px;display:flex}.ag{grid-template-columns:1fr 1fr;gap:6px;margin-bottom:6px;display:grid}.ac{background:var(--s1);border:1px solid var(--bd);border-radius:8px;padding:10px}.ac h3{color:var(--t2);text-transform:uppercase;letter-spacing:.2px;margin-bottom:6px;font-size:10px}.abar{align-items:end;gap:3px;height:80px;display:flex}.abar-item{flex-direction:column;flex:1;align-items:center;gap:2px;display:flex}.abar-item .bar{border-radius:3px 3px 0 0;width:100%;min-height:2px}.abar-item .lb{font:7px var(--m);color:var(--t3);text-align:center;text-overflow:ellipsis;white-space:nowrap;max-width:48px;overflow:hidden}.abar-item .vl{font:600 7px var(--m);color:var(--t1)}.alist{margin-top:4px}.alist-item{border-bottom:1px solid var(--s3);justify-content:space-between;align-items:center;gap:4px;padding:3px 0;font-size:9px;display:flex}.alist-item .name{color:var(--t2);text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.alist-item .val{font:600 9px var(--m);color:var(--t1);white-space:nowrap}th{-webkit-user-select:none;user-select:none;position:relative}th .col-rs{cursor:col-resize;z-index:11;width:7px;position:absolute;top:0;bottom:0;right:-3px}th .col-rs:hover{background:#2563eb4d}th .col-rs.active{background:#2563eb80}.R.fs{z-index:500;border:0;inset:0;width:100%!important;max-width:100%!important;position:fixed!important}.stat{background:var(--s2);border-top:1px solid var(--bd);height:18px;font:8px var(--m);color:var(--t3);justify-content:space-between;align-items:center;padding:0 8px;display:flex}.mv-root{flex-direction:column;flex:1;min-width:0;display:flex;position:relative}.mv-compact{height:100%}.qp-3d-wrap{z-index:500;display:none;position:fixed;inset:0}.qp-3d-wrap.on{display:flex}.qp-3d-viewer{width:var(--qp-split,50%);flex-shrink:0;min-width:200px;display:flex}.qp-3d-dv{cursor:col-resize;background:#7c3aed;flex-shrink:0;width:4px;transition:background .15s}.qp-3d-dv:hover,.qp-3d-dv.dragging{background:#7c3aed99}.qp-3d-content{flex-direction:column;flex:1;min-width:0;display:flex;overflow:hidden}.tl-page{background:var(--bg);height:100vh;font-family:var(--f);color:var(--t1);font-size:12px;display:flex}.tl-page-left{flex:1;min-width:0;display:flex;position:relative}.tl-page-right{border-left:1px solid var(--bd);background:var(--s1);flex-shrink:0;width:340px;overflow:hidden}.toast{background:var(--s1);border:1px solid var(--bd);border-radius:var(--r);opacity:0;z-index:1000;pointer-events:none;padding:5px 12px;font-size:10px;transition:all .2s;position:fixed;bottom:22px;left:50%;transform:translate(-50%)translateY(10px)}.toast.show{opacity:1;transform:translate(-50%)translateY(0)}.drop-zone{z-index:9999;pointer-events:none;background:#3b82f61f;border:3px dashed #3b82f6;justify-content:center;align-items:center;display:none;position:fixed;inset:0}.drop-zone.on{display:flex}.drop-zone-inner{text-align:center;background:#fff;border-radius:16px;padding:40px 60px;box-shadow:0 20px 60px #00000026}.drop-zone-inner h2{font:700 18px var(--f);color:#1e40af;margin:8px 0 4px}.drop-zone-inner p{font:10px var(--f);color:var(--t3)}.load-overlay{z-index:100;background:#ffffffeb;flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex;position:absolute;inset:0}.load-overlay .bar{background:var(--s3);border-radius:3px;width:240px;height:6px;overflow:hidden}.load-overlay .bar-fill{background:linear-gradient(90deg,#3b82f6,#7c3aed);border-radius:3px;height:100%;transition:width .15s}.load-overlay .msg{font:500 11px var(--f);color:var(--t2)}.load-overlay .pct{font:700 24px var(--m);color:#1e40af}.tip3d{color:#fff;font:500 10px var(--f);pointer-events:none;z-index:50;background:#0f172aeb;border-radius:6px;max-width:260px;padding:6px 10px;line-height:1.5;display:none;position:absolute;box-shadow:0 4px 12px #00000040}.tip3d .tip-name{color:#93c5fd;margin-bottom:2px;font-size:11px;font-weight:700}.tip3d .tip-price{color:#fbbf24;font:700 11px var(--m)}.vt#bInfo.on{box-shadow:0 2px 8px #2563eb66;color:#fff!important;background:linear-gradient(135deg,#3b82f6,#2563eb)!important}th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;position:relative}th.sortable:hover{background:#3b82f626!important}th.sortable:after{content:"";color:var(--t3);opacity:.4;font-size:7px;position:absolute;top:50%;right:3px;transform:translateY(-50%)}th.sort-asc:after{content:"▲";opacity:1;color:var(--bl)}th.sort-desc:after{content:"▼";opacity:1;color:var(--bl)}@media print{body:not([data-print-mode])>*{display:none!important}body:not([data-print-mode]) #printArea{z-index:99999;width:100%;position:absolute;top:0;left:0;display:block!important}body:not([data-print-mode]) #printArea *{-webkit-print-color-adjust:exact;print-color-adjust:exact}}#printArea{display:none}#printArea table{border-collapse:collapse;width:100%;font:10px Cordia New,Sarabun,sans-serif}#printArea th{color:#fff;text-align:center;background:#1e40af;border:1px solid #1e40af;padding:6px 8px;font-size:12px}#printArea td{border:1px solid #ddd;padding:4px 6px;font-size:11px}#printArea .pr-l1{color:#1e40af;background:#dbeafe;font:700 13px Cordia New,Sarabun,sans-serif}#printArea .pr-l2{color:#2563eb;background:#eff6ff;font:700 12px Cordia New,Sarabun,sans-serif}#printArea .pr-r{text-align:right;font-family:Courier New,monospace}#printArea .pr-gt{color:#fff;background:#1e40af;font:700 14px Cordia New,Sarabun,sans-serif}#printArea .pr-sub{background:#f1f5f9;font-weight:600}#printArea .pr-header{text-align:center;border-bottom:2px solid #1e40af;margin-bottom:20px;padding:20px 0}#printArea .pr-header h1{color:#1e40af;margin:0;font:700 22px Cordia New,Sarabun,sans-serif}#printArea .pr-header p{color:#475569;margin:4px 0 0;font:12px Cordia New,Sarabun,sans-serif}#printArea .pr-footer{text-align:center;color:#94a3b8;border-top:1px solid #e2e8f0;margin-top:16px;padding-top:8px;font:10px Cordia New,Sarabun,sans-serif}@media print{body{-webkit-print-color-adjust:exact;print-color-adjust:exact;height:auto!important;overflow:visible!important}.main{height:auto!important;overflow:visible!important}.no-print,.tabs,.tbar,.strip,.toast{display:none!important}.print-only{display:block!important}body[data-print-mode=gantt] #scurvePanel,body[data-print-mode=gantt] #milestonePanel,body[data-print-mode=gantt] #timelinePanel{display:none!important}body[data-print-mode=gantt] #ganttPanel{display:flex!important;overflow:visible!important}body[data-print-mode=gantt] .act-list{overflow:visible!important}body[data-print-mode=gantt] .act-list table{font-size:8px!important}body[data-print-mode=gantt] #ganttWrap{overflow:visible!important}body[data-print-mode=milestone] #ganttPanel,body[data-print-mode=milestone] #scurvePanel,body[data-print-mode=milestone] #timelinePanel{display:none!important}body[data-print-mode=milestone] #milestonePanel{padding:0!important;display:block!important;overflow:visible!important}#certReport{border:none!important;max-width:100%!important;padding:16px!important}body[data-print-mode=scurve] #ganttPanel,body[data-print-mode=scurve] #milestonePanel,body[data-print-mode=scurve] #timelinePanel{display:none!important}body[data-print-mode=scurve] #scurvePanel{padding:4px!important;display:block!important;overflow:visible!important}body[data-print-mode=scurve] #scScrollWrap{overflow:visible!important}body[data-print-mode=scurve] #scurveSvg{position:absolute!important}body[data-print-mode=scurve] .b{display:none!important}@page{margin:6mm}}.qplan-page .tabs{background:var(--s1);border-bottom:1px solid var(--bd);padding:0 8px}.qplan-page .tab{font:500 12px var(--f);color:var(--t3);cursor:pointer;background:0;border:none;border-bottom:2px solid #0000;padding:8px 16px;transition:all .15s}.qplan-page .tab:hover{color:var(--t1)}.qplan-page .tab.on{color:var(--pp);border-bottom-color:var(--pp);font-weight:600}.qplan-page .tbar{background:var(--s2);border-bottom:1px solid var(--bd);flex-wrap:wrap;align-items:center;gap:3px;padding:3px 8px;display:flex}.qplan-page .arr{cursor:pointer;margin-right:3px;font-size:8px;transition:transform .2s;display:inline-block}.qplan-page .arr.closed{transform:rotate(-90deg)}.qplan-root{--bg:#f5f6fa;--s1:#fff;--s2:#f8f9fc;--s3:#eef0f6;--hv:#edf0f8;--bd:#dde1eb;--t1:#1e2432;--t2:#4b5268;--t3:#8790a5;--pp:#6c5ce7;--pp2:#5a4bd1;--ppA:#6c5ce714;--ppL:#eeecfb;--bl:#3b82f6;--gn:#22c55e;--gnL:#dcfce7;--or:#f59e0b;--rd:#ef4444;--f:"Noto Sans Thai",sans-serif;--m:"DM Mono",monospace;--r:6px}.main{flex-direction:column;flex:1;display:flex;overflow:hidden}.strip{background:var(--s1);border-bottom:1px solid var(--bd);gap:4px;padding:4px 8px;display:flex}.chip{background:var(--s2);text-align:center;border:1px solid var(--bd);border-radius:5px;flex:1;padding:4px 8px}.chip .n{font:600 12px var(--m);color:var(--t1)}.chip .l{color:var(--t3);text-transform:uppercase;font-size:7px}.chip.pp{background:var(--ppL);border-color:#7c3aed33}.chip.pp .n{color:var(--pp)}.act-wrap{flex:1;display:flex;overflow:hidden}.act-list{border-right:2px solid var(--bd);background:var(--s1);flex-shrink:0;width:640px;min-width:280px;overflow:auto}.act-list table{border-collapse:collapse;width:max-content;min-width:100%}.act-list th{background:var(--ppL);font:600 9px var(--f);text-align:center;color:var(--pp);border:1px solid var(--bd);z-index:5;white-space:nowrap;-webkit-user-select:none;user-select:none;box-sizing:border-box;height:38px;padding:5px 6px;position:relative;top:0}.act-list th .col-rs{cursor:col-resize;z-index:6;width:5px;position:absolute;top:0;bottom:0;right:-2px}.act-list th .col-rs:hover{background:var(--pp)}.act-list td{border-bottom:1px solid var(--s3);white-space:nowrap;text-overflow:ellipsis;box-sizing:border-box;height:29px;padding:4px 6px;font-size:11px;overflow:hidden}.act-list tr:hover{background:var(--hv)}.act-list tr.main-task{background:var(--ppL)}.act-list tr.main-task td{color:var(--pp);border-bottom:2px solid var(--bd);height:33px;padding:5px 6px;font-size:11px;font-weight:700}.act-list tr.main-task:hover{background:#ddd5f5}.act-list tr.sub-task td:nth-child(2){padding-left:20px}.act-list tr.sel{border-left:3px solid #f57c00;background:#ff980026!important}.act-list tr.drop-target{outline:2px dashed var(--pp);background:#7c3aed26!important}.act-list input,.act-list select{font:9px var(--f);color:var(--t1);background:0;border:1px solid #0000;border-radius:2px;padding:1px 3px}.act-list input:focus,.act-list select:focus{border-color:var(--pp);background:var(--s1);outline:0}.act-list input.dt{font:8px var(--m);width:84px}.act-list input.num{text-align:right;font-family:var(--m);width:36px}.gantt-wrap{background:var(--s2);flex:1;position:relative;overflow:auto}.gantt-header{z-index:4;background:var(--ppL);border-bottom:1px solid var(--bd);box-sizing:border-box;height:38px;display:flex;position:sticky;top:0;overflow:hidden}.gantt-hcell{text-align:center;font:600 8px var(--m);color:var(--pp);border-right:1px solid var(--bd);flex-shrink:0}.gantt-hcell .month{font:600 9px var(--f);border-bottom:1px solid var(--bd);background:var(--ppL);padding:2px 0}.gantt-hcell .weeks{display:flex}.gantt-hcell .wk{text-align:center;border-right:1px solid #0000000f;padding:2px;font-size:7px}.gantt-body{position:relative}.gantt-row{border-bottom:1px solid #0000000a;height:29px;position:relative}.gantt-row:hover{background:#6c5ce708}.gantt-row.mt{background:#6c5ce70a;height:33px}.gantt-bar{cursor:pointer;height:14px;font:600 7px var(--m);color:#fff;white-space:nowrap;border-radius:4px;align-items:center;min-width:6px;padding:0 4px;transition:box-shadow .15s,opacity .15s;display:flex;position:absolute;top:50%;overflow:hidden;transform:translateY(-50%);box-shadow:0 1px 4px #0000001a}.gantt-bar:hover{filter:brightness(1.05);box-shadow:0 2px 8px #0003}.gantt-bar.mt-bar{background:linear-gradient(135deg,var(--pp),#8b5cf6);opacity:.7;border-radius:3px;height:18px}.gantt-bar.sub-bar{opacity:.75}.gantt-bar.sub-bar.prog-active,.gantt-bar.sub-bar.prog-done{opacity:1}.gantt-bar .prog-fill{background:#ffffff59;border-right:2px solid #ffffffb3;border-radius:3px 0 0 3px;position:absolute;top:0;bottom:0;left:0}.gantt-bar .prog-text{z-index:2;font:700 7px var(--m);color:#fff;text-shadow:0 1px 2px #00000080;position:relative}.gantt-bar .rh{cursor:ew-resize;width:6px;position:absolute;top:0;bottom:0}.gantt-bar .rh.l{left:0}.gantt-bar .rh.r{right:0}.gantt-today{background:var(--rd);z-index:3;pointer-events:none;width:2px;position:absolute;top:0;bottom:0}.boq-panel{border-left:2px solid var(--bd);background:var(--s1);flex-direction:column;width:260px;display:flex;overflow:hidden}.boq-panel.hidden{display:none}.boq-panel h3{font:600 10px var(--f);color:var(--pp);background:var(--ppL);border-bottom:1px solid var(--bd);padding:6px 8px}.boq-item{border-bottom:1px solid var(--s3);cursor:grab;align-items:center;gap:4px;padding:4px 8px;font-size:9px;display:flex}.boq-item:hover{background:var(--hv)}.boq-item .cost{font:8px var(--m);color:var(--t3);white-space:nowrap;margin-left:auto}.boq-item .desc{text-overflow:ellipsis;white-space:nowrap;flex:1;overflow:hidden}.split-h{background:var(--bd);cursor:col-resize;flex-shrink:0;width:3px}.split-h:hover,.split-h.on{background:var(--pp)}.pm-wrap{border:1px solid var(--bd);background:var(--s1);border-radius:6px;overflow:auto}.pm-wrap table{border-collapse:collapse;font-size:9px}.pm-wrap th{z-index:3;background:var(--ppL);font:600 7px var(--m);border:1px solid var(--bd);text-align:center;white-space:nowrap;min-width:36px;padding:3px 2px;position:sticky;top:0}.pm-wrap th.act-name{z-index:4;text-align:left;min-width:140px;font:600 8px var(--f);background:var(--ppL);padding:3px 6px;position:sticky;left:0}.pm-wrap td{border:1px solid var(--s3);text-align:center;min-width:36px;padding:0}.pm-wrap td.act-name{z-index:2;background:var(--s1);text-align:left;font:9px var(--f);white-space:nowrap;text-overflow:ellipsis;min-width:140px;max-width:160px;padding:2px 6px;position:sticky;left:0;overflow:hidden}.pm-wrap tr.main-row td{background:var(--ppL);color:var(--pp);font-size:8px;font-weight:700}.pm-wrap tr:hover td,.pm-wrap tr:hover td.act-name{background:var(--hv)}.pm-cell{justify-content:center;align-items:center;width:100%;height:100%;min-height:22px;display:flex;position:relative}.pm-cell.in-range{background:#7c3aed0a}.pm-cell.has-plan{background:#7c3aed14}.pm-cell input{text-align:center;width:32px;height:20px;font:8px var(--m);color:var(--t1);background:0 0;border:none;outline:none;padding:0}.pm-cell input:focus{background:var(--s1);box-shadow:inset 0 0 0 1.5px var(--pp);border-radius:2px}.pm-cell input.has-val{color:var(--gn);font-weight:600}.pm-cell .plan-bar{background:var(--pp);opacity:.4;border-radius:1px;height:3px;position:absolute;bottom:0;left:1px;right:1px}.pm-cell .actual-bar{background:var(--gn);border-radius:1px;height:3px;position:absolute;bottom:0;left:1px;right:1px}.pm-totals td{font:600 8px var(--m);border-top:2px solid var(--bd);background:var(--s2)!important}.pm-wrap tr.sc-sel td{border-left:3px solid #f57c00;background:#ff980026!important}.pm-wrap tr.sc-sel td.act-name{background:#ff980026!important}.pm-wrap tr.main-row.sc-sel td{background:#7c3aed33!important}.pm-wrap tr[data-sc-click]{cursor:pointer}.pm-wrap tr[data-sc-click]:hover td:first-child{text-decoration:underline}.boq-drawer{background:var(--s1);border-left:2px solid var(--pp);z-index:500;flex-direction:column;width:400px;transition:right .25s;display:flex;position:fixed;top:0;bottom:0;right:-400px;box-shadow:-4px 0 20px #00000026}.boq-drawer.open{right:0}.boq-drawer .dr-head{background:var(--ppL);border-bottom:1px solid var(--bd);align-items:center;gap:8px;padding:10px 14px;display:flex}.boq-drawer .dr-head h3{font:600 12px var(--f);color:var(--pp);flex:1}.boq-drawer .dr-head .close{cursor:pointer;width:24px;height:24px;color:var(--t3);background:0;border:none;border-radius:4px;font-size:14px}.boq-drawer .dr-head .close:hover{background:var(--hv);color:var(--rd)}.boq-drawer .dr-summary{background:var(--s2);border-bottom:1px solid var(--bd);gap:12px;padding:8px 14px;font-size:10px;display:flex}.boq-drawer .dr-summary .val{font:600 11px var(--m);color:var(--pp)}.boq-drawer .dr-body{flex:1;padding:0;overflow:auto}.boq-drawer .dr-item{border-bottom:1px solid var(--s3);align-items:flex-start;gap:8px;padding:8px 14px;font-size:10px;display:flex;position:relative}.boq-drawer .dr-item:hover{background:var(--hv)}.boq-drawer .dr-item .idx{font:7px var(--m);color:var(--t3);text-align:right;min-width:16px;padding-top:2px}.boq-drawer .dr-item .info{flex:1;min-width:0}.boq-drawer .dr-item .desc{color:var(--t1);margin-bottom:2px;font-weight:500}.boq-drawer .dr-item .meta{font:8px var(--m);color:var(--t3);flex-wrap:wrap;gap:8px;display:flex}.boq-drawer .dr-item .cost{font:600 10px var(--m);color:var(--pp);white-space:nowrap;text-align:right;min-width:70px}.boq-drawer .dr-item .acts{gap:3px;margin-left:auto;display:flex}.boq-drawer .dr-item .acts button{font:8px var(--f);border:1px solid var(--bd);background:var(--s1);cursor:pointer;white-space:nowrap;border-radius:3px;padding:2px 6px}.boq-drawer .dr-item .acts button:hover{background:var(--hv);border-color:var(--pp)}.boq-drawer .dr-item .acts button.rm{color:var(--rd);border-color:#dc26264d}.boq-drawer .dr-item .acts button.rm:hover{background:#dc262614}.boq-drawer .dr-empty{text-align:center;color:var(--t3);padding:30px;font-size:11px}.boq-drawer .dr-foot{background:var(--s2);border-top:1px solid var(--bd);align-items:center;gap:4px;padding:8px 14px;display:flex}.move-picker{background:var(--s1);border:1px solid var(--pp);z-index:10;border-radius:6px;min-width:200px;max-height:200px;padding:4px 0;position:absolute;top:28px;right:8px;overflow:auto;box-shadow:0 4px 16px #00000026}.move-picker .mp-item{cursor:pointer;align-items:center;gap:6px;padding:4px 10px;font-size:9px;display:flex}.move-picker .mp-item:hover{background:var(--hv)}.move-picker .mp-item.mt{color:var(--pp);border-top:1px solid var(--s3);padding-top:6px;font-weight:600}.move-picker .mp-item .dot{border-radius:50%;flex-shrink:0;width:6px;height:6px}
