:root{--bg-app:#d6dde6;--bg-chrome:linear-gradient(180deg, #f4f6f9 0%, #dfe5ed 100%);--bg-chrome-dark:linear-gradient(180deg, #4a5868 0%, #2f3947 100%);--bg-titlebar:linear-gradient(180deg, #1f2937 0%, #0f172a 100%);--bg-panel:#fff;--bg-panel-alt:#f7f9fc;--bg-header:linear-gradient(180deg, #f6f8fb 0%, #e2e7ee 100%);--bg-header-dark:linear-gradient(180deg, #3e4a5b 0%, #2a3340 100%);--bg-row-hover:#eef4fb;--bg-row-stripe:#f7f9fc;--bg-input:#fff;--bg-disabled:#ecf0f5;--b-out:#6b7a8e;--b-in:#b2bcc9;--b-light:#d6dde6;--b-light-2:#e6eaf0;--b-inset-light:#fff;--b-inset-dark:#8a96a8;--t-1:#1a2230;--t-2:#36475d;--t-3:#5d6c80;--t-mute:#8392a5;--t-on-dark:#ecf2fa;--t-on-dark-2:#b3c0d2;--acc:#0b5fb5;--acc-2:#08488d;--acc-soft:#d6e5f5;--acc-hover:linear-gradient(180deg, #2a7bc9 0%, #0b5fb5 100%);--ok:#2e7d32;--warn:#b76e00;--warn-bg:#fff4dd;--warn-border:#e0a64d;--danger:#b3261e;--danger-bg:#fde7e7;--danger-border:#d99490;--f-ui:"Segoe UI", Tahoma, "Sarabun", "Microsoft Sans Serif", sans-serif;--f-mono:"IBM Plex Mono", "Consolas", "Lucida Console", "Courier New", monospace;--f-thai:"Sarabun", "Tahoma", sans-serif;--sidebar-w:220px;--titlebar-h:26px;--menubar-h:24px;--ribbon-h:70px;--statusbar-h:22px}*{box-sizing:border-box;margin:0;padding:0}html,body{background:var(--bg-app);color:var(--t-1);font-family:var(--f-ui);font-size:12px;line-height:1.4}body{min-height:100vh;padding-bottom:var(--statusbar-h)}button{font:inherit;color:inherit;cursor:pointer}a{color:inherit;text-decoration:none}.mono{font-family:var(--f-mono)}.num{font-variant-numeric:tabular-nums;font-family:var(--f-mono)}.appbar{color:#e1e8f4;-webkit-user-select:none;user-select:none;background:linear-gradient(#2a3a52 0%,#142031 100%);border-bottom:1px solid #000;align-items:stretch;height:36px;font-size:12px;display:flex;box-shadow:inset 0 -1px #ffffff0f}.appbar-brand{background:linear-gradient(#1f2d42 0%,#0c1624 100%);border-right:1px solid #000;align-items:center;gap:8px;padding:0 14px 0 12px;display:flex;box-shadow:inset -1px 0 #ffffff0d}.appbar-mark{background:linear-gradient(135deg,#6cb6ee 0%,#0b5fb5 60%,#052f64 100%);border:1px solid #03203f;width:18px;height:18px;position:relative;box-shadow:inset 0 1px #fff6,0 1px #0006}.appbar-mark:after{content:"";border:none;border-top:1.5px solid #ffffffd9;border-left:1.5px solid #ffffffd9;position:absolute;inset:3px;transform:rotate(45deg)}.appbar-name{letter-spacing:.04em;color:#f4f7fb;text-shadow:0 1px #0006;font-size:12px;font-weight:700}.appbar-name span{color:#7c97bd;margin-left:4px;font-weight:400}.appbar-crumb{color:#aab9d0;border-right:1px solid #0006;align-items:center;gap:7px;padding:0 14px;font-size:11.5px;display:flex;box-shadow:inset -1px 0 #ffffff0a}.appbar-crumb .sep{color:#5d7290}.appbar-crumb .leaf{color:#f4f7fb;font-weight:600}.appbar-crumb svg{opacity:.7;width:13px;height:13px}.appbar-search{background:#00000040;border-left:1px solid #ffffff0a;border-right:1px solid #0006;align-items:center;gap:6px;width:320px;padding:0 10px;display:flex}.appbar-search svg{color:#7c97bd;width:13px;height:13px}.appbar-search input{color:#e1e8f4;font:inherit;background:0 0;border:none;outline:none;flex:1;padding:0}.appbar-search input::placeholder{color:#6f85a4;font-style:italic}.appbar-search kbd{font-family:var(--f-mono);color:#aab9d0;background:#ffffff0f;border:1px solid #ffffff1a;padding:1px 5px;font-size:10px;box-shadow:inset 0 -1px #0006}.appbar-spacer{flex:1}.appbar-tool{color:#c5d2e6;cursor:default;border-left:1px solid #0006;align-items:center;gap:6px;padding:0 12px;font-size:11.5px;display:flex;position:relative;box-shadow:inset 1px 0 #ffffff0a}.appbar-tool:hover{color:#f4f7fb;background:#ffffff0d}.appbar-tool svg{width:14px;height:14px}.appbar-tool .badge{background:var(--warn);color:#1a0e00;font-family:var(--f-mono);border:1px solid #6e4500;justify-content:center;align-items:center;min-width:14px;height:14px;padding:0 4px;font-size:9px;font-weight:700;display:inline-flex;box-shadow:0 0 4px #f5c34480}.appbar-tool .led-dot{background:#4ade80;border:1px solid #166534;width:7px;height:7px;box-shadow:0 0 4px #4ade80,inset 0 1px #ffffff80}.appbar-tool .ux{flex-direction:column;align-items:flex-end;line-height:1.15;display:flex}.appbar-tool .ux .u{color:#f4f7fb;font-size:11.5px;font-weight:600}.appbar-tool .ux .r{font-family:var(--f-mono);color:#7c97bd;letter-spacing:.04em;text-transform:uppercase;font-size:9.5px}.appbar-tool .av{color:#fff;width:22px;height:22px;font-size:10px;font-weight:700;font-family:var(--f-ui);background:linear-gradient(135deg,#6cb6ee 0%,#0b5fb5 100%);border:1px solid #052f64;place-items:center;display:grid;box-shadow:inset 0 1px #ffffff4d}.appbar-tool .chev{color:#7c97bd;font-size:9px}.subbar{border-bottom:1px solid var(--b-out);background:linear-gradient(#f4f6f9 0%,#dde4ed 100%);align-items:stretch;height:30px;padding:0;display:flex;box-shadow:inset 0 1px #fff}.subbar-section{color:var(--t-2);border-right:1px solid #c4cdda;align-items:center;gap:6px;padding:0 10px;font-size:11.5px;display:flex;box-shadow:inset -1px 0 #fff}.subbar-section .lbl{color:var(--t-3);text-transform:uppercase;letter-spacing:.06em;font-size:10px;font-weight:600}.sb-btn{color:var(--t-1);cursor:pointer;background:linear-gradient(#fdfdfe 0%,#e2e8f0 100%);border:1px solid #98a4b5;align-items:center;gap:5px;height:22px;padding:2px 8px;font-size:11px;display:inline-flex;box-shadow:inset 0 1px #fff}.sb-btn:hover{background:linear-gradient(#fff8c8 0%,#fde9a3 100%);border-color:#b8860b}.sb-btn:active{background:linear-gradient(#d4d8df 0%,#b8c0cc 100%);box-shadow:inset 0 1px 2px #00000026}.sb-btn.primary{color:#fff;text-shadow:0 -1px #0003;background:linear-gradient(#2a7bc9 0%,#0b5fb5 100%);border-color:#08488d}.sb-btn.primary:hover{background:linear-gradient(#3e8ed8 0%,#1670c8 100%)}.sb-btn svg{width:13px;height:13px}.sb-btn .chev{color:var(--t-3);margin-left:2px;font-size:8px}.period-input{height:22px;font-family:var(--f-mono);color:var(--t-1);background:#fff;border:1px solid #98a4b5;align-items:center;gap:6px;padding:1px 8px;font-size:11px;display:inline-flex;box-shadow:inset 0 1px 1px #0000000f}.period-input svg{width:12px;height:12px;color:var(--t-3)}.period-input .arrow{color:var(--t-3);cursor:pointer;padding:0 2px;font-size:10px}.period-input .arrow:hover{color:var(--acc)}.subbar-spacer{box-shadow:none;border-right:none;flex:1}.live-block{align-items:center;gap:8px;font-size:11px;display:flex}.live-block .key{color:var(--t-3)}.live-block .val{font-family:var(--f-mono);color:var(--t-1);font-weight:600}.menubar{height:var(--menubar-h);border-bottom:1px solid var(--b-in);-webkit-user-select:none;user-select:none;background:linear-gradient(#e9eef5 0%,#d2dae5 100%);align-items:center;padding:0 4px;font-size:12px;display:flex}.menu-item{color:var(--t-1);cursor:default;padding:3px 10px}.menu-item:hover{background:linear-gradient(#cbe1f7 0%,#a6c8eb 100%);border:1px solid #6a8db8;padding:2px 9px}.menu-item u{text-decoration:underline}.ribbon{display:none}.ribbon-legacy{background:var(--bg-chrome);border-bottom:1px solid var(--b-in);height:var(--ribbon-h);align-items:stretch;gap:0;padding:4px 6px;display:flex}.ribbon-group{border-right:1px solid #c4cdda;flex-direction:column;min-width:0;padding:0 8px;display:flex}.ribbon-group-body{flex:1;align-items:center;gap:4px;display:flex}.ribbon-group-label{color:var(--t-3);text-align:center;letter-spacing:.02em;border-top:1px solid #d6dde6;margin-top:2px;padding-top:2px;font-size:10px}.rb-btn{color:var(--t-1);cursor:pointer;background:linear-gradient(#fdfdfe 0%,#e2e8f0 100%);border:1px solid #98a4b5;align-items:center;gap:5px;height:22px;padding:2px 8px;font-size:11px;display:inline-flex;box-shadow:inset 0 1px #fff}.rb-btn:hover{background:linear-gradient(#fff8c8 0%,#fde9a3 100%);border-color:#b8860b}.rb-btn:active{background:linear-gradient(#d4d8df 0%,#b8c0cc 100%);box-shadow:inset 0 1px 2px #00000026}.rb-btn.lg{flex-direction:column;gap:4px;min-width:64px;height:56px;padding:4px 10px;font-size:11px}.rb-btn.lg .ico{place-items:center;width:24px;height:24px;display:grid}.rb-btn.primary{color:#fff;text-shadow:0 -1px #0003;background:linear-gradient(#2a7bc9 0%,#0b5fb5 100%);border-color:#08488d}.rb-btn.primary:hover{background:linear-gradient(#3e8ed8 0%,#1670c8 100%)}.rb-sep{background:#c4cdda;width:1px;height:50px;margin:4px}.rb-btn .ico svg{width:14px;height:14px}.rb-btn.lg .ico svg{width:20px;height:20px}.app{grid-template-columns:var(--sidebar-w) 1fr;border-left:1px solid var(--b-out);border-right:1px solid var(--b-out);background:var(--bg-app);display:grid}.sidebar{border-right:1px solid var(--b-in);min-height:calc(100vh - 36px - 30px - var(--statusbar-h));background:linear-gradient(#eef2f7 0%,#d8e0eb 100%);flex-direction:column;display:flex}.nav-section{border-bottom:1px solid #c4cdda}.nav-section-head{color:#f4f7fb;letter-spacing:.02em;text-shadow:0 -1px #0000004d;cursor:default;background:linear-gradient(#5d6e85 0%,#3e4a5b 100%);border-top:1px solid #7a8a9f;border-bottom:1px solid #2a3340;align-items:center;padding:5px 10px;font-size:11px;font-weight:600;display:flex}.nav-section-head .triangle{margin-right:6px;font-size:8px}.nav-list{padding:2px 0}.nav-item{color:var(--t-1);cursor:default;border-top:1px solid #0000;border-bottom:1px solid #0000;align-items:center;gap:8px;padding:4px 10px 4px 14px;font-size:12px;display:flex}.nav-item:hover{background:linear-gradient(#cbe1f7 0%,#a6c8eb 100%);border-top-color:#b6d4ee;border-bottom-color:#6a8db8}.nav-item.active{background:linear-gradient(#fde394 0%,#f5c344 100%);border-top-color:#ffe9a8;border-bottom-color:#c89614;font-weight:600}.nav-item svg{width:14px;height:14px;color:var(--t-2);flex-shrink:0}.nav-item.active svg{color:#6e4f00}.main{background:var(--bg-app);flex-direction:column;gap:8px;padding:8px;display:flex;overflow:hidden}.doc-tabs{border-bottom:2px solid var(--acc);align-items:end;gap:0;margin-bottom:-1px;padding-left:8px;display:flex}.doc-tab{border:1px solid var(--b-in);color:var(--t-2);cursor:default;background:linear-gradient(#e8eef6 0%,#c8d3e0 100%);border-bottom:none;border-radius:3px 3px 0 0;align-items:center;gap:6px;margin-right:1px;padding:4px 14px 5px;font-size:12px;display:inline-flex}.doc-tab .x{color:var(--t-mute);padding-left:4px;font-size:10px}.doc-tab.active{color:var(--acc);border-color:var(--acc);z-index:2;background:linear-gradient(#fff 0% 100%);border-bottom-color:#fff;font-weight:600;position:relative}.form-head{background:var(--bg-header);border:1px solid var(--b-in);border-top:2px solid var(--acc);align-items:center;gap:16px;padding:8px 12px;display:flex}.form-head h1{color:var(--acc-2);text-transform:uppercase;letter-spacing:.04em;font-size:14px;font-weight:700}.form-head .sep{background:var(--b-in);width:1px;height:18px}.form-head .meta{color:var(--t-3);align-items:center;gap:14px;font-size:11px;display:flex}.form-head .meta b{color:var(--t-1);font-weight:600}.form-head .right{align-items:center;gap:8px;margin-left:auto;font-size:11px;display:flex}.form-head .right .key{color:var(--t-mute)}.form-head .right .val{font-family:var(--f-mono);color:var(--t-1);font-weight:600}.indicator{letter-spacing:.04em;text-transform:uppercase;border:1px solid;align-items:center;gap:5px;padding:2px 8px;font-size:10px;font-weight:600;display:inline-flex}.indicator.ok{color:var(--ok);background:#e6f4e8;border-color:#a6cdaa}.indicator.warn{background:var(--warn-bg);border-color:var(--warn-border);color:var(--warn)}.indicator.live:before{content:"";background:#2e7d32;width:6px;height:6px;animation:1.4s ease-in-out infinite pulse;box-shadow:0 0 0 1px #fff,0 0 4px #2e7d32}@keyframes pulse{50%{opacity:.4}}.row{gap:8px;display:grid}.row.cols-4{grid-template-columns:repeat(4,1fr)}.row.cols-2-1{grid-template-columns:2fr 1fr}.row.cols-1-1{grid-template-columns:1fr 1fr}.panel{background:var(--bg-panel);border:1px solid var(--b-in);flex-direction:column;min-width:0;display:flex;box-shadow:inset 0 1px #fff}.panel-head{background:var(--bg-header);border-bottom:1px solid var(--b-in);color:var(--t-1);text-transform:uppercase;letter-spacing:.03em;align-items:center;gap:8px;height:24px;padding:4px 10px;font-size:11px;font-weight:700;display:flex}.panel-head .accent{background:var(--acc);width:3px;height:12px;margin-right:4px}.panel-head .right{color:var(--t-3);text-transform:none;letter-spacing:0;align-items:center;gap:6px;margin-left:auto;font-size:10px;font-weight:400;display:flex}.panel-head a{color:var(--acc);cursor:pointer}.panel-head a:hover{text-decoration:underline}.panel-body{flex:1;min-height:0;padding:10px 12px}.kpi-board{border:1px solid var(--b-out);background:#fff;flex-direction:column;display:flex;box-shadow:inset 0 1px #fff,0 1px #0000000a}.kpi-board-head{color:#f4f7fb;background:linear-gradient(#3b4d68 0%,#1f2d42 100%);border-bottom:1px solid #000;align-items:stretch;height:30px;padding:0;display:flex;box-shadow:inset 0 -1px #ffffff0f}.kpi-board-title{letter-spacing:.05em;text-transform:uppercase;text-shadow:0 1px #0006;border-right:1px solid #0006;align-items:center;gap:8px;padding:0 12px;font-size:11.5px;font-weight:700;display:flex;box-shadow:inset -1px 0 #ffffff0d}.kpi-board-title .accent{background:var(--acc);width:3px;height:14px;box-shadow:0 0 4px #0b5fb599}.kpi-board-meta{color:#aab9d0;border-right:1px solid #0006;align-items:center;gap:10px;padding:0 12px;font-size:10.5px;display:flex;box-shadow:inset -1px 0 #ffffff0a}.kpi-board-meta .k{color:#7c97bd;text-transform:uppercase;letter-spacing:.06em;font-size:10px}.kpi-board-meta .v{color:#f4f7fb;font-family:var(--f-mono);font-weight:600}.kpi-board-spacer{flex:1}.kpi-board-actions{align-items:stretch;display:flex}.kbh-tab{color:#aab9d0;cursor:default;text-transform:uppercase;letter-spacing:.04em;border-left:1px solid #0006;align-items:center;gap:5px;padding:0 12px;font-size:11px;display:flex;box-shadow:inset 1px 0 #ffffff0a}.kbh-tab:hover{color:#f4f7fb;background:#ffffff0d}.kbh-tab.active{color:var(--acc-2);box-shadow:inset 0 -2px 0 var(--acc), inset 0 1px 0 #fff;background:linear-gradient(#f4f6f9 0%,#dde4ed 100%);font-weight:700}.kbh-tab svg{width:12px;height:12px}.kpi-board-body{background:#c4cdda;grid-template-columns:repeat(4,1fr);gap:1px;display:grid}.kpi-cell{background:linear-gradient(#fff 0%,#f7f9fc 100%);grid-template-rows:auto auto auto;grid-template-columns:1fr;gap:6px;min-height:124px;padding:10px 14px 12px;display:grid;position:relative}.kpi-cell:before{content:"";background:linear-gradient(90deg, var(--acc) 0%, transparent 100%);height:2px;position:absolute;top:0;left:0;right:0}.kpi-cell.warn:before{background:linear-gradient(90deg, var(--warn) 0%, transparent 100%)}.kpi-cell.mute:before{background:linear-gradient(90deg, var(--t-mute) 0%, transparent 100%)}.kpi-cell-head{justify-content:space-between;align-items:center;gap:8px;display:flex}.kpi-cell-id{color:var(--t-3);text-transform:uppercase;letter-spacing:.08em;align-items:center;gap:6px;font-size:10px;font-weight:700;display:inline-flex}.kpi-cell-id .seq{font-family:var(--f-mono);background:var(--acc);color:#fff;letter-spacing:0;border:1px solid var(--acc-2);padding:1px 6px;font-size:9.5px;box-shadow:inset 0 1px #ffffff4d}.kpi-cell.warn .kpi-cell-id .seq{background:var(--warn);border-color:#6e4500}.kpi-cell.mute .kpi-cell-id .seq{background:var(--t-mute);border-color:#4a5868}.kpi-cell-id .label{color:var(--t-2)}.kpi-cell-id .label .th{color:var(--t-3);text-transform:none;letter-spacing:0;font-weight:400;font-family:var(--f-thai);margin-left:4px;font-size:11px}.kpi-cell-tag{font-family:var(--f-mono);color:var(--t-3);letter-spacing:.04em;border:1px solid var(--b-in);background:var(--bg-panel-alt);padding:1px 5px;font-size:9.5px;box-shadow:inset 0 1px #fff}.kpi-cell-body{grid-template-columns:1fr 92px;align-items:end;gap:8px;display:grid}.kpi-cell-num{font-family:var(--f-mono);align-items:baseline;gap:4px;line-height:1;display:flex}.kpi-cell-num .n{color:var(--t-1);letter-spacing:-.01em;font-size:28px;font-weight:700}.kpi-cell.warn .kpi-cell-num .n{color:var(--warn)}.kpi-cell.mute .kpi-cell-num .n{color:var(--t-mute)}.kpi-cell-num .u{color:var(--t-3);font-size:11px;font-family:var(--f-thai)}.kpi-spark{background:linear-gradient(0deg,#0000 0 calc(50% - 1px),#e6eaf0 50%,#0000 calc(50% + 1px)),linear-gradient(#fff 0%,#f4f6f9 100%);border:1px inset #b2bcc9;height:32px;position:relative;overflow:hidden}.kpi-spark svg{width:100%;height:100%;position:absolute;inset:0}.kpi-spark .lbl{font-family:var(--f-mono);color:var(--t-mute);letter-spacing:.04em;font-size:8.5px;line-height:1;position:absolute;bottom:1px;right:3px}.kpi-spark .empty-line{background:repeating-linear-gradient(90deg, var(--b-in) 0 3px, transparent 3px 6px);height:1px;position:absolute;top:50%;left:0;right:0}.kpi-cell-foot{border-top:1px solid var(--b-light);grid-template-columns:1fr 1fr;gap:0;padding-top:6px;font-size:10.5px;display:grid}.kpi-cell-foot .item{border-right:1px dotted var(--b-light);flex-direction:column;gap:1px;padding-right:8px;display:flex}.kpi-cell-foot .item:last-child{border-right:none;padding-left:8px;padding-right:0}.kpi-cell-foot .k{color:var(--t-mute);text-transform:uppercase;letter-spacing:.06em;font-size:9.5px;font-weight:600}.kpi-cell-foot .v{font-family:var(--f-mono);color:var(--t-1);font-size:11px;font-weight:600}.kpi-cell-foot .v.warn{color:var(--warn)}.kpi-cell-foot .v.mute{color:var(--t-mute)}.kpi-cell-foot .v.ok{color:var(--ok)}.kpi-cell-foot .delta{align-items:center;gap:2px;display:inline-flex}.kpi-cell-foot .delta.up{color:var(--ok)}.kpi-cell-foot .delta.down{color:var(--danger)}.kpi-cell-foot .delta.flat{color:var(--t-mute)}.grid{border-collapse:separate;border-spacing:0;background:#fff;width:100%;font-size:12px}.grid th{border:1px solid var(--b-in);text-align:left;color:var(--t-2);text-transform:uppercase;letter-spacing:.02em;background:linear-gradient(#e9eef5 0%,#cad4e1 100%);border-left:none;height:22px;padding:4px 8px;font-size:11px;font-weight:700;position:sticky;top:0}.grid th:first-child{border-left:1px solid var(--b-in)}.grid th.right{text-align:right}.grid th .sort{color:var(--t-mute);margin-left:4px;font-size:9px}.grid td{border-bottom:1px solid var(--b-light-2);border-right:1px solid var(--b-light);height:22px;color:var(--t-1);vertical-align:middle;padding:3px 8px}.grid td:first-child{border-left:1px solid var(--b-light)}.grid tr:nth-child(2n) td{background:var(--bg-row-stripe)}.grid tr:hover td{background:var(--bg-row-hover)}.grid td.right{text-align:right;font-family:var(--f-mono)}.grid td.code{font-family:var(--f-mono);color:var(--t-2);font-size:11px}.grid td.center{text-align:center}.grid tr.selected td{background:#fff4c2;border-bottom-color:#d8b94c}.grid tfoot td{border-top:2px solid var(--b-in);height:24px;color:var(--t-1);background:linear-gradient(#f0f4fa 0%,#dfe6f0 100%);font-weight:700}.mini-bar{vertical-align:middle;border:1px solid var(--b-in);background:#f0f3f8;width:80px;height:8px;display:inline-block;position:relative;box-shadow:inset 0 1px 1px #0000000d}.mini-bar>span{background:linear-gradient(#4ea3e0 0%,#0b5fb5 100%);position:absolute;top:0;bottom:0;left:0}.mini-bar.warn>span{background:linear-gradient(#f5c344 0%,#b76e00 100%)}.mini-bar.zero>span{background:#b2bcc9}.pill{border:1px solid var(--b-in);color:var(--t-2);text-transform:uppercase;letter-spacing:.02em;background:linear-gradient(#fff 0%,#f0f3f8 100%);align-items:center;gap:4px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-flex}.pill.warn{background:var(--warn-bg);border-color:var(--warn-border);color:var(--warn)}.pill.danger{background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger)}.pill.ok{color:var(--ok);background:#e6f4e8;border-color:#a6cdaa}.stat-frame{border:1px solid var(--b-in);background:#fff;flex-direction:column;display:flex}.stat-frame .stat-head{border-bottom:1px solid var(--warn-border);color:var(--warn);text-transform:uppercase;letter-spacing:.04em;background:linear-gradient(#fff4dd 0%,#ffe5b3 100%);justify-content:space-between;align-items:center;padding:4px 10px;font-size:11px;font-weight:700;display:flex}.stat-frame.idle .stat-head{border-bottom-color:var(--b-in);color:var(--t-3);background:linear-gradient(#f0f3f8 0%,#dde3eb 100%)}.stat-frame .stat-body{align-items:baseline;gap:8px;padding:10px 12px 8px;display:flex}.stat-frame .stat-body .n{font-family:var(--f-mono);color:var(--warn);font-size:32px;font-weight:700;line-height:1}.stat-frame.idle .stat-body .n{color:var(--t-mute)}.stat-frame .stat-body .lbl{color:var(--t-3);font-size:11px}.stat-frame .stat-foot{border-top:1px solid var(--b-light-2);background:var(--bg-panel-alt);color:var(--t-3);justify-content:space-between;align-items:center;padding:5px 10px;font-size:11px;display:flex}.stat-frame .stat-desc{color:var(--t-2);padding:2px 12px 8px;font-size:11px}.gauge-grid{grid-template-columns:130px 1fr;align-items:center;gap:12px;display:grid}.gauge{width:130px;height:130px;position:relative}.gauge svg{transform:rotate(-90deg)}.gauge .center{flex-direction:column;justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.gauge .pct{font-family:var(--f-mono);color:var(--warn);font-size:22px;font-weight:700}.gauge .pct-lbl{text-transform:uppercase;color:var(--t-3);letter-spacing:.06em;font-size:10px}.gauge-stats{border:1px solid var(--b-in);flex-direction:column;gap:0;display:flex}.gauge-stats .gs-row{border-bottom:1px solid var(--b-light-2);grid-template-columns:14px 1fr auto;align-items:center;gap:8px;padding:4px 8px;font-size:11px;display:grid}.gauge-stats .gs-row:last-child{border-bottom:none}.gauge-stats .gs-row:nth-child(2n){background:var(--bg-row-stripe)}.gauge-stats .swatch{border:1px solid var(--b-in);width:10px;height:10px}.gauge-stats .v{font-family:var(--f-mono);color:var(--t-1);font-weight:700}.chart-frame{background:linear-gradient(0deg,#0000 0 calc(20% - 1px),#e6eaf0 20%,#0000 calc(20% + 1px) calc(40% - 1px),#e6eaf0 40%,#0000 calc(40% + 1px) calc(60% - 1px),#e6eaf0 60%,#0000 calc(60% + 1px) calc(80% - 1px),#e6eaf0 80%,#0000 calc(80% + 1px)),linear-gradient(90deg,#0000 0 calc(10% - 1px),#f0f3f8 10%,#0000 calc(10% + 1px) calc(20% - 1px),#f0f3f8 20%,#0000 calc(20% + 1px) calc(30% - 1px),#f0f3f8 30%,#0000 calc(30% + 1px) calc(40% - 1px),#f0f3f8 40%,#0000 calc(40% + 1px) calc(50% - 1px),#e6eaf0 50%,#0000 calc(50% + 1px) calc(60% - 1px),#f0f3f8 60%,#0000 calc(60% + 1px) calc(70% - 1px),#f0f3f8 70%,#0000 calc(70% + 1px) calc(80% - 1px),#f0f3f8 80%,#0000 calc(80% + 1px) calc(90% - 1px),#f0f3f8 90%,#0000 calc(90% + 1px)),linear-gradient(#fff 0%,#f7f9fc 100%);border:1px inset #b2bcc9;height:240px;margin:4px 0;position:relative}.chart-axis-y{width:30px;font-family:var(--f-mono);color:var(--t-3);text-align:right;flex-direction:column;justify-content:space-between;font-size:10px;display:flex;position:absolute;top:4px;bottom:22px;left:4px}.chart-axis-x{font-family:var(--f-mono);color:var(--t-3);justify-content:space-between;font-size:10px;display:flex;position:absolute;bottom:2px;left:38px;right:8px}.chart-empty-overlay{justify-content:center;align-items:center;display:flex;position:absolute;inset:0}.chart-empty-card{border:1px solid var(--b-in);text-align:center;background:#fff;max-width:320px;padding:14px 22px;box-shadow:0 2px 4px #00000014}.chart-empty-card .lbl1{color:var(--t-2);margin-bottom:4px;font-size:12px;font-weight:700}.chart-empty-card .lbl2{color:var(--t-3);font-size:11px}.chart-empty-card .lbl3{font-size:10px;font-family:var(--f-mono);color:var(--t-mute);border-top:1px dotted var(--b-light);letter-spacing:.04em;margin-top:6px;padding-top:6px}.legend{gap:14px;display:flex}.legend-item{color:var(--t-2);align-items:center;gap:5px;font-size:11px;display:inline-flex}.legend-item .sw{border:1px solid #6b7a8e;width:10px;height:10px}.statusbar{height:var(--statusbar-h);border-top:1px solid var(--b-in);color:var(--t-2);z-index:50;background:linear-gradient(#e9eef5 0%,#cad4e1 100%);align-items:center;padding:0;font-size:11px;display:flex;position:fixed;bottom:0;left:0;right:0}.sb-cell{border-right:1px solid #b2bcc9;align-items:center;gap:6px;height:100%;padding:0 10px;display:flex;box-shadow:inset 1px 0 #fff}.sb-cell.flex{flex:1}.sb-cell .key{color:var(--t-3)}.sb-cell .val{color:var(--t-1);font-weight:600;font-family:var(--f-mono)}.sb-cell .led{background:#2e7d32;border:1px solid #6b7a8e;width:8px;height:8px;box-shadow:0 0 4px #2e7d3299,inset 0 1px 1px #fff6}.sb-cell .led.warn{background:var(--warn);box-shadow:0 0 4px #b76e0099,inset 0 1px 1px #fff6}#tweaks-root{z-index:100;position:fixed;bottom:28px;right:10px}.hr{border-top:1px solid var(--b-in);border-bottom:1px solid #fff;margin:0}:root{font-feature-settings:"tnum" on, "lnum" on}#root{min-height:100vh}a{color:inherit}.login-shell{background:var(--bg-app);place-items:center;min-height:100vh;padding:24px;display:grid}.login-card{background:var(--bg-panel);border:1px solid var(--b-out);width:100%;max-width:420px;box-shadow:0 8px 24px #0000001f,inset 0 1px #fff}.login-head{color:#ecf2fa;background:linear-gradient(#2a3a52 0%,#142031 100%);border-bottom:1px solid #000;align-items:center;gap:12px;padding:14px 16px;display:flex;box-shadow:inset 0 -1px #ffffff0f}.login-title{letter-spacing:.04em;color:#f4f7fb;text-shadow:0 1px #0006;font-size:14px;font-weight:700}.login-title .sub{color:#7c97bd;margin-left:4px;font-weight:400}.login-sub{color:#aab9d0;font-size:10.5px;font-family:var(--f-mono);letter-spacing:.04em;text-transform:uppercase;margin-top:2px}.login-form{flex-direction:column;gap:12px;padding:18px 20px 14px;display:flex}.login-form .fld{flex-direction:column;gap:4px;display:flex}.login-form .fld .lbl{font-family:var(--f-mono);color:var(--t-3);text-transform:uppercase;letter-spacing:.08em;font-size:10px;font-weight:700}.login-form .ip-wrap{display:block;position:relative}.login-form .ip-wrap .ico{color:var(--t-mute);pointer-events:none;position:absolute;top:50%;left:8px;transform:translateY(-50%)}.login-form .ip-wrap input{width:100%;height:28px;padding-left:28px;font-size:12px}.login-err{background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger);font-size:11.5px;font-family:var(--f-thai);padding:6px 10px}.login-foot{border-top:1px solid var(--b-light);background:var(--bg-panel-alt);padding:12px 20px 14px}.login-hint{color:var(--t-3);font-size:11px;font-family:var(--f-thai);line-height:1.6}.login-hint strong{color:var(--t-1);font-family:var(--f-ui)}.login-hint code{font-family:var(--f-mono);border:1px solid var(--b-in);color:var(--acc-2);background:#0b5fb514;padding:0 4px;font-size:10.5px}.login-hint ul{margin-top:6px;padding-left:16px;list-style:square}.login-hint li{margin:2px 0}@media (width<=920px){:root{--sidebar-w:0px;--titlebar-h:22px;--menubar-h:22px;--ribbon-h:56px}.app{border-left:none;border-right:none;grid-template-columns:1fr}.sidebar{width:240px;height:calc(100vh - 36px - var(--statusbar-h));z-index:50;border-right:1px solid var(--b-out);transition:transform .18s ease-out;position:fixed;top:36px;left:0;transform:translate(-100%);box-shadow:2px 0 8px #00000026}.app.menu-open .sidebar{transform:translate(0)!important}.app.menu-open:before{content:"";inset:36px 0 var(--statusbar-h) 0;z-index:40;background:#0f172a73;position:fixed}.appbar-search{display:none}.appbar-crumb{text-overflow:ellipsis;white-space:nowrap;max-width:50%;font-size:11px;overflow:hidden}.appbar-tool .ux{display:none}.mobile-menu-toggle{appearance:none;color:var(--t-on-dark);cursor:pointer;background:0 0;border:none;align-items:center;margin-right:4px;padding:6px 8px;display:inline-flex}.mobile-menu-toggle:hover{background:#ffffff14}.subbar{height:auto;min-height:var(--ribbon-h);flex-wrap:wrap;gap:4px;padding:6px 8px}.subbar-section{border-right:none;flex-wrap:wrap}.subbar-spacer{display:none}.row.cols-2-1,.row.cols-1-1,.row.cols-4{grid-template-columns:1fr}.form-head{flex-direction:column;align-items:flex-start;gap:6px}.form-head .meta{flex-direction:column;gap:2px;font-size:11px}.panel-body{overflow-x:auto}button,.btn,a.btn{min-height:36px}[role=dialog][data-state=open]{border-radius:0;width:100vw;max-width:100vw;height:100dvh;max-height:100dvh;inset:0}.update-banner{bottom:80px!important}.offline-toast{top:60px!important}}.period-rocker,.branch-toggle{align-items:center;gap:6px;display:flex}.seg-group{border:1px solid var(--b-in);background:var(--bg-panel-alt);border-radius:3px;display:inline-flex;overflow:hidden}.seg,.seg-on{appearance:none;border:none;border-right:1px solid var(--b-light);font-family:var(--f-mono);letter-spacing:.04em;color:var(--t-2);cursor:pointer;background:0 0;align-items:center;gap:4px;min-height:28px;padding:6px 10px;font-size:10.5px;display:inline-flex}.seg:last-child,.seg-on:last-child{border-right:none}.seg:hover{background:var(--bg-row-hover);color:var(--t-1)}.seg-on{background:var(--acc);color:var(--t-on-dark);font-weight:600}.seg-on .led,.seg .led{background:var(--t-mute);border-radius:50%;width:6px;height:6px;display:inline-block}.seg-on .led{background:var(--ok);box-shadow:0 0 4px var(--ok)}.kpi-row{grid-template-columns:repeat(6,1fr);gap:8px;margin-bottom:8px;display:grid}.kpi-tile{background:var(--bg-panel);border:1px solid var(--b-in);border-top:2px solid var(--acc);flex-direction:column;gap:2px;min-height:80px;padding:10px 12px;display:flex}.kpi-label{letter-spacing:.06em;text-transform:uppercase;color:var(--t-3);font-size:10px;font-weight:600}.kpi-big-number{color:var(--t-1);font-variant-numeric:tabular-nums;margin-top:4px;font-size:28px;font-weight:700;line-height:1.1}@media (width<=920px){.kpi-big-number{font-size:22px}.kpi-row,.kpi-row-mobile,.branch-strip{grid-template-columns:1fr}.ar-aging-totals{grid-template-columns:repeat(2,1fr)}.ar-aging-table th:last-child,.ar-aging-table td:last-child{display:none}}.mobile-cta-wrap{justify-content:center;margin-top:8px;display:flex}.mobile-cta{background:var(--acc);color:var(--t-on-dark);letter-spacing:.04em;border-radius:4px;padding:14px 24px;font-size:13px;font-weight:700;text-decoration:none;display:inline-block}.mobile-cta:hover{background:var(--acc-2)}.kpi-sublabel{font-family:var(--f-thai);color:var(--t-3);font-size:11px}.branch-strip{grid-template-columns:repeat(3,1fr);gap:8px;display:grid}.branch-card{border:1px solid var(--b-in);background:var(--bg-panel-alt);flex-direction:column;gap:4px;min-height:140px;padding:10px 12px;display:flex}.branch-card-head{border-bottom:1px dotted var(--b-light);align-items:center;gap:6px;margin-bottom:4px;padding-bottom:6px;display:flex}.branch-card-head .branch-code{font-family:var(--f-mono);letter-spacing:.06em;color:var(--t-1);font-size:13px;font-weight:700}.branch-card-head .branch-name{font-family:var(--f-thai);color:var(--t-3);font-size:12px}.branch-card-row{justify-content:space-between;align-items:baseline;font-size:12px;display:flex}.branch-card-row .lbl{letter-spacing:.04em;color:var(--t-3);text-transform:uppercase;font-size:10px}.branch-card-row .num{font-variant-numeric:tabular-nums;color:var(--t-1);font-weight:600}.pnl-chart-wrap{width:100%;min-width:0}.ar-aging-totals{grid-template-columns:repeat(4,1fr);gap:6px;margin-bottom:10px;display:grid}.ar-aging-total{border:1px solid var(--b-in);background:var(--bg-panel-alt);border-left-width:3px;padding:6px 8px}.ar-aging-total-0-30{border-left-color:var(--ok)}.ar-aging-total-31-60{border-left-color:var(--warn)}.ar-aging-total-60-plus{border-left-color:var(--danger)}.ar-aging-total-grand{border-left-color:var(--acc)}.ar-aging-total .lbl{letter-spacing:.04em;color:var(--t-3);text-transform:uppercase;font-size:10px}.ar-aging-total .val{color:var(--t-1);margin-top:2px;font-size:14px;font-weight:700}.ar-aging-table{border-collapse:collapse;width:100%;font-size:12px}.ar-aging-table th,.ar-aging-table td{border-bottom:1px solid var(--b-light);text-align:left;padding:6px 8px}.ar-aging-table th{letter-spacing:.04em;color:var(--t-3);text-transform:uppercase;background:var(--bg-header);font-size:10px;font-weight:600}.ar-aging-table tr:hover{background:var(--bg-row-hover)}.ar-aging-table .num{font-variant-numeric:tabular-nums}.age-bar-track{background:var(--bg-row-stripe);border-radius:2px;width:100%;min-width:60px;height:8px;position:relative}.age-bar-fill{border-radius:2px;transition:width .2s ease-out;position:absolute;inset:0 auto 0 0}.age-bar-fill.aging-0-30{background:var(--ok)}.age-bar-fill.aging-31-60{background:var(--warn)}.age-bar-fill.aging-60-plus{background:var(--danger)}.approval-queue-table{border-collapse:collapse;width:100%;font-size:12px}.approval-queue-table th,.approval-queue-table td{border-bottom:1px solid var(--b-light);text-align:left;padding:6px 8px}.approval-queue-table th{letter-spacing:.04em;color:var(--t-3);text-transform:uppercase;background:var(--bg-header);font-size:10px;font-weight:600}.approval-queue-table tr:hover{background:var(--bg-row-hover)}.pill{letter-spacing:.04em;text-transform:uppercase;background:var(--bg-panel-alt);border:1px solid var(--b-in);color:var(--t-2);border-radius:8px;padding:1px 6px;font-size:10px;font-weight:600;display:inline-block}.pill-discount{background:var(--warn-bg);border-color:var(--warn-border);color:var(--warn)}.pill-stock_adjustment{background:var(--acc-soft);border-color:var(--acc);color:var(--acc)}.pill-supplier_payment{background:var(--danger-bg);border-color:var(--danger-border);color:var(--danger)}.approval-cta{color:var(--acc);font-size:11px;font-weight:600;text-decoration:none}.approval-cta:hover{text-decoration:underline}
