/* Based on uploaded jt_ocr_ui.html */
:root {
  --B:   #ffffff; --B1:  #f5f5f3; --B2:  #eeede9; --B3:  #e2e0db; --B4:  #d0cec8; --B5:  #b0aea6;
  --W:   #1a1a18; --W1:  #2e2e2c; --W2:  #4a4a46; --W3:  #6e6e68; --W4:  #9a9992;
  --R:   #d42020; --R1:  rgba(212,32,32,.12); --R2:  rgba(212,32,32,.05); --G:   #1a9e52; --Y:   #c08a00;
  --mono: 'Martian Mono', monospace; --thai: 'Noto Sans Thai', sans-serif;
}
*,*::before,*::after{margin:0;padding:0;box-sizing:border-box}
html,body{height:100%;overflow:hidden;background:var(--B);color:var(--W);font-family:var(--mono);font-size:12px;cursor:crosshair}
::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:var(--B2)}::-webkit-scrollbar-thumb{background:var(--B4)}
.shell{display:grid;grid-template-rows:44px 1fr;grid-template-columns:306px 1fr;grid-template-areas:"top top" "side body";height:100vh}
.topbar{grid-area:top;background:var(--B);border-bottom:2px solid var(--B5);display:flex;align-items:stretch;position:relative;z-index:200}.topbar::before{content:'';width:4px;background:var(--R);flex-shrink:0}
.tb-logo{display:flex;align-items:center;padding:0 18px;gap:10px;border-right:1px solid var(--B4);flex-shrink:0}.tb-wm{font-size:17px;font-weight:800;letter-spacing:-0.5px;color:var(--W)}.tb-wm em{color:var(--R);font-style:normal}.tb-sub{font-size:7px;letter-spacing:4px;color:var(--W3);border:1px solid var(--B4);padding:3px 7px;background:var(--B2)}
.tb-tags{display:flex;align-items:center;padding:0 14px;gap:6px;border-right:1px solid var(--B3)}.tb-tag{font-size:8px;letter-spacing:2px;color:var(--W3);border:1px solid var(--B4);padding:3px 8px;background:var(--B1);text-transform:uppercase}.tb-tag.alert{color:var(--R);border-color:var(--R1)}
.tb-status{display:flex;align-items:center;gap:9px;padding:0 16px;border-right:1px solid var(--B3)}.s-led{width:8px;height:8px;border-radius:50%;background:var(--B5);flex-shrink:0;transition:background .3s,box-shadow .3s}.s-led.run{background:var(--R);box-shadow:0 0 10px var(--R);animation:led .8s ease-in-out infinite}.s-led.done{background:var(--G)}.s-led.err{background:var(--Y)}@keyframes led{0%,100%{opacity:1;transform:scale(1)}50%{opacity:.4;transform:scale(.7)}}.s-txt{font-size:9px;font-weight:600;letter-spacing:3px;color:var(--W2);transition:color .2s;text-transform:uppercase}.s-txt.run{color:var(--R)}.s-txt.done{color:var(--G)}.s-txt.err{color:var(--Y)}
.tb-right{margin-left:auto;display:flex;align-items:center}.tb-clock{padding:0 18px;font-size:14px;font-weight:300;letter-spacing:2px;color:var(--W3);border-left:1px solid var(--B3);height:100%;display:flex;align-items:center}
.sidebar{grid-area:side;background:var(--B1);border-right:2px solid var(--B5);display:flex;flex-direction:column;overflow:hidden}.s-head{display:flex;align-items:center;height:30px;flex-shrink:0}.s-head-bar{width:3px;height:100%;background:var(--R);flex-shrink:0}.s-head-lbl{padding:0 12px;font-size:7px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--W3);border-bottom:1px solid var(--B3);height:100%;display:flex;align-items:center;flex:1}.s-scroll{flex:1;min-height:0;overflow-y:auto;padding:12px 0;display:flex;flex-direction:column;gap:0}.fg{padding:0 13px 13px;border-bottom:1px solid var(--B3);margin-bottom:13px}.fg:last-child{border-bottom:none;margin-bottom:0}.fg-lbl{font-size:7px;font-weight:600;letter-spacing:3px;text-transform:uppercase;color:var(--W3);margin-bottom:8px;display:flex;align-items:center;gap:8px}.fg-lbl::after{content:'';flex:1;height:1px;background:var(--B4)}
.f-input,.f-select,.f-textarea{width:100%;background:var(--B2);border:1px solid var(--B5);border-left:2px solid var(--B5);color:var(--W1);font-family:var(--mono);font-size:10px;padding:8px 10px;outline:none;transition:border-left-color .15s;letter-spacing:.5px}.f-input:focus,.f-select:focus,.f-textarea:focus{border-left-color:var(--R)}.f-input::placeholder{color:var(--W4)}.f-select{cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='8' height='5'%3E%3Cpath d='M0 0l4 5 4-5z' fill='%23585852'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;padding-right:28px}.f-select option{background:var(--B1)}.f-textarea{font-size:9px;resize:vertical;min-height:80px;line-height:1.7}.f-hint{margin-top:5px;font-size:8px;letter-spacing:.3px;color:var(--W4);line-height:1.6;font-family:var(--thai)}
.src-tabs{display:grid;grid-template-columns:1fr 1fr;border:1px solid var(--B5);overflow:hidden;margin-bottom:10px}.src-tab{padding:8px 0;text-align:center;font-size:8px;font-weight:600;letter-spacing:2px;text-transform:uppercase;color:var(--W4);background:var(--B2);border:none;cursor:pointer;border-right:1px solid var(--B5);position:relative;transition:all .12s}.src-tab:last-child{border-right:none}.src-tab:hover{color:var(--W2);background:var(--B3)}.src-tab.on{color:var(--W);background:var(--B)}.src-tab.on::after{content:'';position:absolute;bottom:0;left:0;right:0;height:2px;background:var(--R)}.tp{display:none}.tp.on{display:flex;flex-direction:column;gap:9px}
.dz{border:1px dashed var(--B5);padding:16px 12px;text-align:center;cursor:pointer;transition:all .15s;background:var(--B2)}.dz:hover,.dz.over{border-color:var(--W3);background:var(--B3)}.dz.ok{border-style:solid;border-color:var(--G);background:rgba(46,204,113,.04)}.dz-ico{width:30px;height:30px;border:1px solid var(--B5);display:flex;align-items:center;justify-content:center;margin:0 auto 7px;color:var(--W4);transition:all .15s}.dz:hover .dz-ico,.dz.over .dz-ico{border-color:var(--W3);color:var(--W2)}.dz.ok .dz-ico{border-color:var(--G);color:var(--G)}.dz-title{font-size:10px;font-weight:600;color:var(--W1);letter-spacing:.5px;margin-bottom:3px}.dz-sub{font-size:8px;color:var(--W4);letter-spacing:.5px}
.fi{display:none;flex-direction:column;border:1px solid var(--B5);overflow:hidden}.fi.on{display:flex}.fi-row{display:flex;justify-content:space-between;padding:5px 10px;border-bottom:1px solid var(--B3);font-size:9px}.fi-row:last-child{border-bottom:none}.fi-k{color:var(--W4);letter-spacing:1px;text-transform:uppercase}.fi-v{color:var(--W1);max-width:148px;text-align:right;word-break:break-all}
.folder-list{display:flex;flex-direction:column;border:1px solid var(--B5);overflow:hidden;max-height:130px;overflow-y:auto}.f-item{display:flex;align-items:center;justify-content:space-between;padding:7px 10px;border-bottom:1px solid var(--B3);cursor:pointer;font-size:9px;transition:background .1s;letter-spacing:.5px}.f-item:last-child{border-bottom:none}.f-item:hover{background:var(--B3)}.f-item.sel{background:var(--B4);border-left:2px solid var(--R)}.f-dt{color:var(--W1);font-weight:600}.f-ct{color:var(--W3)}
.param{display:flex;flex-direction:column;gap:5px}.param-row{display:flex;align-items:baseline;justify-content:space-between}.param-key{font-size:7px;font-weight:600;letter-spacing:2.5px;text-transform:uppercase;color:var(--W3)}.param-num{font-size:14px;font-weight:700;color:var(--W);letter-spacing:-0.5px}.param-note{font-family:var(--thai);font-size:9px;color:var(--W4);line-height:1.5}input[type=range]{width:100%;-webkit-appearance:none;height:2px;background:var(--B5);outline:none;cursor:pointer}input[type=range]::-webkit-slider-thumb{-webkit-appearance:none;width:13px;height:13px;background:var(--W);cursor:pointer;border-radius:0;transition:background .1s}input[type=range]:hover::-webkit-slider-thumb{background:var(--R)}
.action-bar{padding:11px 13px;border-top:2px solid var(--B5);display:grid;grid-template-columns:1fr 1fr 1fr;gap:7px;flex-shrink:0;background:var(--B)}.btn{font-family:var(--mono);font-size:9px;font-weight:600;letter-spacing:1.5px;text-transform:uppercase;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:6px;padding:10px 12px;transition:all .12s;min-width:0}.btn:disabled{opacity:.25;cursor:not-allowed}.btn-go{background:var(--W);color:var(--B);border-radius:2px}.btn-go:not(:disabled):hover{background:var(--R);color:var(--W)}.btn-pause{background:transparent;color:var(--Y);border:1px solid var(--Y);border-radius:2px}.btn-pause:not(:disabled):hover{background:rgba(240,192,64,.1);border-color:var(--Y)}.btn-stop{background:transparent;color:var(--W3);border:1px solid var(--B5);border-radius:2px}.btn-stop:not(:disabled):hover{border-color:var(--R);color:var(--R)}
.body{grid-area:body;display:flex;flex-direction:column;min-height:0;overflow:hidden}
.metrics{display:grid;grid-template-columns:repeat(5,1fr) auto;border-bottom:2px solid var(--B5);background:var(--B);flex-shrink:0}.metric{padding:13px 18px;border-right:1px solid var(--B4);position:relative}.metric::before{content:attr(data-label);display:block;font-size:6px;font-weight:600;letter-spacing:4px;text-transform:uppercase;color:var(--W4);margin-bottom:4px}.mnum{font-size:28px;font-weight:800;line-height:1;letter-spacing:-2px;color:var(--W);transition:color .3s}.mnum.dim{color:var(--B5)}.mnum.red{color:var(--R)}.mnum.grn{color:var(--G)}.mnum.ylw{color:var(--Y)}.mstrip{position:absolute;bottom:0;left:0;right:0;height:2px}.meta-eta{padding:13px 20px;display:flex;flex-direction:column;justify-content:center;gap:3px;min-width:100px}.meta-eta::before{content:'ETA';font-size:6px;letter-spacing:4px;color:var(--W4);text-transform:uppercase}.eta-val{font-size:20px;font-weight:800;color:var(--W2);letter-spacing:-1px;transition:color .3s}
.prog-row{display:none;height:34px;padding:0 18px;background:var(--B1);border-bottom:1px solid var(--B4);align-items:center;gap:14px;flex-shrink:0}.prog-row.on{display:flex}.prog-file{font-size:8px;letter-spacing:.5px;color:var(--W3);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;min-width:0;flex:1}.prog-track{flex:3;height:2px;background:var(--B5);position:relative}.prog-fill{position:absolute;top:0;left:0;bottom:0;background:var(--W);width:0%;transition:width .3s cubic-bezier(.4,0,.2,1)}.prog-fill::after{content:'';position:absolute;right:0;top:-2px;bottom:-2px;width:2px;background:var(--R);box-shadow:0 0 6px var(--R)}.prog-fill.done{background:var(--G)}.prog-fill.done::after{display:none}.prog-pct{font-size:11px;font-weight:700;color:var(--W);min-width:40px;text-align:right;letter-spacing:.5px}.prog-pct.done{color:var(--G)}
.content{flex:1;min-height:0;display:flex;flex-direction:column;overflow:hidden}.empty{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:14px}.empty-x{position:relative;width:56px;height:56px;opacity:.1}.empty-x::before,.empty-x::after{content:'';position:absolute;background:var(--W)}.empty-x::before{width:2px;height:100%;left:50%;transform:translateX(-50%)}.empty-x::after{height:2px;width:100%;top:50%;transform:translateY(-50%)}.empty-lbl{font-size:9px;font-weight:600;letter-spacing:4px;color:var(--W4);text-transform:uppercase}.empty-sub{font-family:var(--thai);font-size:10px;color:var(--B5)}
.gallery{display:none;flex:1;flex-direction:column;overflow:hidden}.gallery.on{display:flex}.gal-bar{padding:7px 15px;border-bottom:1px solid var(--B4);display:flex;align-items:center;gap:9px;background:var(--B1);flex-shrink:0}.gal-cnt{font-size:8px;letter-spacing:2px;color:var(--W3);text-transform:uppercase}.gal-filters{display:flex;gap:2px;margin-left:auto}.gf{font-size:7px;font-weight:600;letter-spacing:2px;padding:4px 10px;border:1px solid var(--B5);background:transparent;color:var(--W4);cursor:pointer;text-transform:uppercase;transition:all .1s}.gf:hover{border-color:var(--W4);color:var(--W3)}.gf.on{border-color:var(--W);color:var(--W);background:var(--B4)}.gal-grid{flex:1;overflow-y:auto;padding:9px;display:grid;grid-template-columns:repeat(auto-fill,minmax(178px,1fr));gap:7px;align-content:start}
.card{background:var(--B2);border:1px solid var(--B4);display:flex;flex-direction:column;cursor:pointer;transition:border-color .12s,transform .1s;animation:fu .2s ease forwards;opacity:0;position:relative}.card:hover{border-color:var(--W3);transform:translateY(-2px)}.card.c-ok{border-left:2px solid var(--G)}.card.c-warn{border-left:2px solid var(--Y)}.card.c-err{border-left:2px solid var(--R)}@keyframes fu{from{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.card-img{height:100px;background:var(--B3);position:relative;overflow:hidden;display:flex;align-items:center;justify-content:center}.card-img img{width:100%;height:100%;object-fit:cover;opacity:.55;transition:opacity .2s}.card:hover .card-img img{opacity:.8}.card-num-bg{font-size:28px;font-weight:800;color:var(--B5);letter-spacing:-2px;user-select:none;position:absolute}.card-corner{position:absolute;top:5px;left:5px;font-size:7px;letter-spacing:1px;color:var(--W4);background:rgba(0,0,0,.75);padding:2px 5px}.card-badge{position:absolute;top:5px;right:5px;font-size:7px;font-weight:700;letter-spacing:1.5px;padding:2px 6px;text-transform:uppercase}.card-badge.scanning{background:rgba(248,248,244,.07);color:var(--W3);border:1px solid var(--B5)}.card-badge.ok{background:rgba(46,204,113,.12);color:var(--G);border:1px solid rgba(46,204,113,.3)}.card-badge.warn{background:rgba(240,192,64,.1);color:var(--Y);border:1px solid rgba(240,192,64,.3)}.card-badge.err{background:rgba(232,48,48,.1);color:var(--R);border:1px solid rgba(232,48,48,.3)}.card-prog{position:absolute;bottom:0;left:0;right:0;height:2px}.card-prog.ok{background:var(--G)}.card-prog.warn{background:var(--Y)}.card-prog.err{background:var(--R)}.card-info{padding:7px 9px;border-top:1px solid var(--B4);display:flex;flex-direction:column;gap:2px}.c-wb{font-size:9px;color:var(--W1);letter-spacing:.5px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.c-nm{font-family:var(--thai);font-size:10px;color:var(--W2);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.c-tel{font-size:8px;color:var(--W4);letter-spacing:1.5px}
.bot-bar{background:var(--B);border-top:2px solid var(--B5);padding:7px 18px;display:flex;align-items:center;gap:12px;flex-shrink:0}.bot-stat{font-size:8px;letter-spacing:.5px;color:var(--W4)}.bot-stat b{color:var(--W2)}.exp-btn{display:none;align-items:center;gap:6px;padding:5px 12px;font-family:var(--mono);font-size:8px;font-weight:700;letter-spacing:2px;text-transform:uppercase;border:1px solid var(--B5);background:transparent;color:var(--W3);cursor:pointer;transition:all .12s}.exp-btn.on{display:flex}.exp-btn:hover{border-color:var(--W);color:var(--W)}.exp-btn.xlsx{border-color:rgba(46,204,113,.3);color:var(--G);margin-left:auto}.exp-btn.xlsx:hover{border-color:var(--G);background:rgba(46,204,113,.06)}
.terminal{background:var(--B1);border-top:2px solid var(--B5);height:103px;display:flex;flex-direction:column;flex-shrink:0}.term-top{display:flex;align-items:center;padding:0 13px;height:25px;border-bottom:1px solid var(--B4);gap:7px;flex-shrink:0}.mac{width:7px;height:7px;border-radius:50%;background:var(--B5)}.mac.r{background:#e05252}.mac.y{background:#d4a017}.mac.g{background:#3aaf67}.term-ttl{margin-left:5px;font-size:7px;letter-spacing:3px;color:var(--W4);text-transform:uppercase}.term-cnt{margin-left:auto;font-size:7px;letter-spacing:2px;color:var(--W4)}.term-body{flex:1;overflow-y:auto;padding:5px 13px;font-size:9px;line-height:2;letter-spacing:.3px}.tl{color:var(--W4)}.tl.ok{color:var(--G)}.tl.err{color:var(--R)}.tl.warn{color:var(--Y)}.tl.info{color:var(--W2)}.tl:last-child::after{content:'█';animation:bk .8s step-end infinite;opacity:.5;color:var(--W3);margin-left:2px}@keyframes bk{0%,100%{opacity:.5}50%{opacity:0}}
.modal-bg{display:none;position:fixed;inset:0;background:rgba(0,0,0,.45);z-index:1000;align-items:center;justify-content:center}.modal-bg.on{display:flex}.modal-box{background:var(--B1);border:1px solid var(--B5);border-top:3px solid var(--R);width:min(640px,92vw);max-height:88vh;display:flex;flex-direction:column;overflow:hidden;animation:min .15s ease}@keyframes min{from{opacity:0;transform:translateY(-12px)}to{opacity:1;transform:translateY(0)}}.modal-head{display:flex;align-items:center;padding:10px 13px;border-bottom:1px solid var(--B4)}.modal-ttl{font-size:9px;font-weight:700;letter-spacing:2px;text-transform:uppercase;color:var(--W1)}.modal-cls{margin-left:auto;padding:3px 10px;font-family:var(--mono);font-size:8px;font-weight:700;letter-spacing:2px;border:1px solid var(--B5);background:transparent;color:var(--W3);cursor:pointer;text-transform:uppercase;transition:all .1s}.modal-cls:hover{border-color:var(--R);color:var(--R)}.modal-fields{padding:13px;display:grid;grid-template-columns:1fr 1fr;gap:6px}.mf{background:var(--B2);border:1px solid var(--B4);border-left:2px solid var(--B5);padding:8px 10px;display:flex;flex-direction:column;gap:3px}.mf.full{grid-column:1/-1}.mf.hit{border-left-color:var(--G)}.mf.warn{border-left-color:var(--Y)}.mf-k{font-size:7px;font-weight:600;letter-spacing:2px;color:var(--W4);text-transform:uppercase}.mf-v{font-size:10px;color:var(--W1);word-break:break-all;letter-spacing:.3px}.mf-v.grn{color:var(--G)}.mf-v.ylw{color:var(--Y)}
.tb-menu{display:none;align-items:center;justify-content:center;width:44px;height:100%;border:none;background:transparent;cursor:pointer;border-right:1px solid var(--B3);flex-shrink:0}.tb-menu span{display:block;width:16px;height:2px;background:var(--W);position:relative;transition:all .2s}.tb-menu span::before,.tb-menu span::after{content:'';position:absolute;left:0;width:100%;height:2px;background:var(--W);transition:all .2s}.tb-menu span::before{top:-5px}.tb-menu span::after{top:5px}.tb-menu.open span{background:transparent}.tb-menu.open span::before{top:0;transform:rotate(45deg)}.tb-menu.open span::after{top:0;transform:rotate(-45deg)}
.side-overlay{display:none;position:fixed;inset:0;background:rgba(0,0,0,.35);z-index:299;opacity:0;transition:opacity .25s}.side-overlay.on{display:block;opacity:1}
@media(max-width:1024px){.shell{grid-template-columns:260px 1fr}.tb-sub{display:none}.tb-tags{padding:0 10px;gap:4px}.tb-tag{font-size:7px;padding:2px 6px;letter-spacing:1px}.tb-clock{padding:0 12px;font-size:12px}.metrics{grid-template-columns:repeat(3,1fr) auto}.metric:nth-child(4),.metric:nth-child(5){display:none}.metric{padding:10px 14px}.mnum{font-size:22px}.eta-val{font-size:16px}.gal-grid{grid-template-columns:repeat(auto-fill,minmax(155px,1fr))}}
@media(max-width:768px){html,body{overflow:auto;cursor:default}.shell{grid-template-columns:1fr;grid-template-rows:44px 1fr;grid-template-areas:"top top" "body body"}.tb-menu{display:flex}.tb-tags{display:none}.tb-logo{padding:0 12px;gap:6px}.tb-wm{font-size:14px}.tb-status{padding:0 10px;border-right:none}.tb-clock{padding:0 10px;font-size:11px}.sidebar{position:fixed;top:44px;left:0;bottom:0;width:min(320px,85vw);z-index:300;transform:translateX(-100%);transition:transform .25s ease;border-right:2px solid var(--B5);box-shadow:4px 0 20px rgba(0,0,0,.1)}.sidebar.open{transform:translateX(0)}.metrics{grid-template-columns:repeat(3,1fr);overflow-x:auto}.metric:nth-child(4),.metric:nth-child(5){display:none}.metric{padding:9px 12px}.mnum{font-size:20px}.meta-eta{min-width:70px;padding:9px 12px}.eta-val{font-size:15px}.prog-row{padding:0 12px;gap:8px}.gal-bar{padding:6px 12px;flex-wrap:wrap;gap:6px}.gal-filters{margin-left:0;flex-wrap:wrap}.gf{padding:3px 8px;font-size:6px}.gal-grid{padding:7px;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:6px}.card-img{height:80px}.card-num-bg{font-size:22px}.card-info{padding:5px 7px}.c-wb{font-size:8px}.c-nm{font-size:9px}.bot-bar{padding:6px 12px;flex-wrap:wrap;gap:8px}.exp-btn{padding:4px 10px;font-size:7px}.terminal{height:80px}.term-body{font-size:8px;padding:4px 10px}.modal-box{width:95vw;max-height:80vh}.modal-fields{grid-template-columns:1fr;padding:10px}.action-bar{grid-template-columns:1fr 1fr 1fr;gap:5px;padding:9px 10px}.btn{font-size:8px;padding:9px 8px;letter-spacing:1px;gap:4px}}
@media(max-width:480px){.gal-grid{grid-template-columns:repeat(auto-fill,minmax(120px,1fr));gap:5px}.card-img{height:65px}.metrics{grid-template-columns:repeat(2,1fr) auto}.metric:nth-child(3){display:none}}
