/*! tailwindcss v4.3.0 | MIT License | https://tailwindcss.com */@import "https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Thai:wght@400;500;600;700&family=IBM+Plex+Sans:wght@400;500;600;700&family=IBM+Plex+Mono:wght@400;500;600&display=swap";@layer properties{@supports (((-webkit-hyphens:none)) and (not (margin-trim:inline))) or ((-moz-orient:inline) and (not (color:rgb(from red r g b)))){*,::backdrop,:after,:before{--tw-border-style:solid;--tw-outline-style:solid;--tw-ease:initial}}}@layer theme{:host,:root{--font-sans:ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji";--font-mono:ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace;--spacing:.25rem;--radius-lg:.5rem;--shadow-lg:0 10px 15px -3px #0000001a,0 4px 6px -4px #0000001a;--ease-in-out:cubic-bezier(.4,0,.2,1);--default-transition-duration:.15s;--default-transition-timing-function:cubic-bezier(.4,0,.2,1);--default-font-family:var(--font-sans);--default-mono-font-family:var(--font-mono)}}@layer base{*,::backdrop,:after,:before{box-sizing:border-box;border:0 solid;margin:0;padding:0}::file-selector-button{box-sizing:border-box;border:0 solid;margin:0;padding:0}:host,html{-webkit-text-size-adjust:100%;tab-size:4;line-height:1.5;font-family:var(--default-font-family,ui-sans-serif,system-ui,sans-serif,"Apple Color Emoji","Segoe UI Emoji","Segoe UI Symbol","Noto Color Emoji");font-feature-settings:var(--default-font-feature-settings,normal);font-variation-settings:var(--default-font-variation-settings,normal);-webkit-tap-highlight-color:transparent}hr{height:0;color:inherit;border-top-width:1px}abbr:where([title]){-webkit-text-decoration:underline dotted;text-decoration:underline dotted}h1,h2,h3,h4,h5,h6{font-size:inherit;font-weight:inherit}a{color:inherit;-webkit-text-decoration:inherit;text-decoration:inherit}b,strong{font-weight:bolder}code,kbd,pre,samp{font-family:var(--default-mono-font-family,ui-monospace,SFMono-Regular,Menlo,Monaco,Consolas,"Liberation Mono","Courier New",monospace);font-feature-settings:var(--default-mono-font-feature-settings,normal);font-variation-settings:var(--default-mono-font-variation-settings,normal);font-size:1em}small{font-size:80%}sub,sup{vertical-align:baseline;font-size:75%;line-height:0;position:relative}sub{bottom:-.25em}sup{top:-.5em}table{text-indent:0;border-color:inherit;border-collapse:collapse}:-moz-focusring{outline:auto}progress{vertical-align:baseline}summary{display:list-item}menu,ol,ul{list-style:none}audio,canvas,embed,iframe,img,object,svg,video{vertical-align:middle;display:block}img,video{max-width:100%;height:auto}button,input,optgroup,select,textarea{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}::file-selector-button{font:inherit;font-feature-settings:inherit;font-variation-settings:inherit;letter-spacing:inherit;color:inherit;opacity:1;background-color:#0000;border-radius:0}:where(select:is([multiple],[size])) optgroup{font-weight:bolder}:where(select:is([multiple],[size])) optgroup option{padding-inline-start:20px}::file-selector-button{margin-inline-end:4px}::placeholder{opacity:1}@supports (not ((-webkit-appearance:-apple-pay-button))) or (contain-intrinsic-size:1px){::placeholder{color:currentColor}@supports (color:color-mix(in lab,red,red)){::placeholder{color:color-mix(in oklab,currentcolor 50%,transparent)}}}textarea{resize:vertical}::-webkit-search-decoration{-webkit-appearance:none}::-webkit-date-and-time-value{min-height:1lh;text-align:inherit}::-webkit-datetime-edit{display:inline-flex}::-webkit-datetime-edit-fields-wrapper{padding:0}::-webkit-datetime-edit,::-webkit-datetime-edit-year-field{padding-block:0}::-webkit-datetime-edit-day-field,::-webkit-datetime-edit-month-field{padding-block:0}::-webkit-datetime-edit-hour-field,::-webkit-datetime-edit-minute-field{padding-block:0}::-webkit-datetime-edit-millisecond-field,::-webkit-datetime-edit-second-field{padding-block:0}::-webkit-datetime-edit-meridiem-field{padding-block:0}::-webkit-calendar-picker-indicator{line-height:1}:-moz-ui-invalid{box-shadow:none}button,input:where([type=button],[type=reset],[type=submit]){appearance:button}::file-selector-button{appearance:button}::-webkit-inner-spin-button,::-webkit-outer-spin-button{height:auto}[hidden]:where(:not([hidden=until-found])){display:none!important}}@layer components;@layer utilities{.absolute{position:absolute}.fixed{position:fixed}.relative{position:relative}.static{position:static}.sticky{position:sticky}.block{display:block}.flex{display:flex}.grid{display:grid}.hidden{display:none}.inline{display:inline}.inline-block{display:inline-block}.inline-flex{display:inline-flex}.table{display:table}.size-1{width:calc(var(--spacing) * 1);height:calc(var(--spacing) * 1)}.grid-cols-3{grid-template-columns:repeat(3,minmax(0,1fr))}.grid-cols-4{grid-template-columns:repeat(4,minmax(0,1fr))}.border{border-style:var(--tw-border-style);border-width:1px}.uppercase{text-transform:uppercase}.outline{outline-style:var(--tw-outline-style);outline-width:1px}.transition{transition-property:color,background-color,border-color,outline-color,text-decoration-color,fill,stroke,--tw-gradient-from,--tw-gradient-via,--tw-gradient-to,opacity,box-shadow,transform,translate,scale,rotate,filter,-webkit-backdrop-filter,backdrop-filter,display,content-visibility,overlay,pointer-events;transition-timing-function:var(--tw-ease,var(--default-transition-timing-function));transition-duration:var(--tw-duration,var(--default-transition-duration))}.ease-in-out{--tw-ease:var(--ease-in-out);transition-timing-function:var(--ease-in-out)}}:root{--bg:#fafaf7;--surface:#fff;--surface-2:#f6f4ee;--border:#e8e5dd;--border-soft:#f1efe8;--ink:#111;--ink-2:#4a4a45;--ink-3:#7a7a72;--ink-4:#a8a8a0;--accent:#facc15;--accent-ink:#0f0f0f;--brand:#0f0f0f;--ok:#16a34a;--ok-bg:#e7f6ec;--warn:#b7791f;--warn-bg:#fef3c7;--danger:#dc2626;--danger-bg:#fee4e2;--info:#2563eb;--info-bg:#e0eafe;--radius:8px;--radius-lg:12px;--shadow:0 1px 0 #0f0f0f0a,0 1px 2px #0f0f0f0d;--shadow-lg:0 8px 24px #0f0f0f14,0 2px 6px #0f0f0f0a;--sidebar-w:248px;--topbar-h:60px}[data-theme=dark]{--bg:#0b0b0a;--surface:#161614;--surface-2:#1e1e1b;--border:#2a2a26;--border-soft:#232320;--ink:#f4f2ec;--ink-2:#b8b5ac;--ink-3:#88857c;--ink-4:#585551;--ok-bg:#0f2417;--warn-bg:#2a1f0a;--danger-bg:#2a1212;--info-bg:#0d1a33;--shadow:0 1px 0 #00000080;--shadow-lg:0 10px 30px #00000080}[data-theme=industrial]{--bg:#1a1d1a;--surface:#232723;--surface-2:#2c302c;--border:#393e39;--border-soft:#303530;--ink:#f0ede0;--ink-2:#b0ac9e;--ink-3:#807c71;--ink-4:#555149;--accent:#facc15;--brand:#0a0c0a;--ok-bg:#1a2e1f;--warn-bg:#2e2410;--danger-bg:#2e1414;--info-bg:#122438}*{box-sizing:border-box}body,html{background:var(--bg);color:var(--ink);-webkit-font-smoothing:antialiased;margin:0;font-family:IBM Plex Sans Thai,IBM Plex Sans,-apple-system,BlinkMacSystemFont,Helvetica,Arial,sans-serif;font-size:14px;line-height:1.5}.app-shell{height:100vh}.app-shell,.sidebar{display:flex;overflow:hidden}.sidebar{width:var(--sidebar-w);min-width:var(--sidebar-w);background:var(--brand);flex-direction:column;position:relative}.sidebar:after{content:"";pointer-events:none;background:linear-gradient(#facc150f,#0000 40%);position:absolute;inset:0}.main-area{flex-direction:column;flex:1;display:flex;overflow:hidden}.topbar{height:var(--topbar-h);min-height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);-webkit-backdrop-filter:blur(12px)saturate(180%);backdrop-filter:blur(12px)saturate(180%);z-index:40;box-shadow:var(--shadow);align-items:center;gap:12px;padding:0 20px;display:flex;position:sticky;top:0}.page-content{background:var(--bg);flex:1;padding:28px 32px;overflow-y:auto}.sidebar-brand{border-bottom:1px solid #ffffff14;align-items:center;gap:10px;padding:18px 20px;display:flex}.sidebar-brand img{filter:brightness(0)invert();width:auto;height:28px}.sidebar-brand-text{color:#fff;letter-spacing:.04em;text-transform:uppercase;font-size:13px;font-weight:700}.nav-section-label{letter-spacing:.1em;text-transform:uppercase;color:#ffffff59;padding:16px 20px 6px;font-size:10px;font-weight:600}.nav-item{color:#fff9;cursor:pointer;text-align:left;background:0 0;border:none;border-radius:0;align-items:center;gap:10px;width:100%;padding:9px 20px;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .15s;display:flex;position:relative}.nav-item:hover{color:#fff;background:#ffffff0f;padding-left:24px}.nav-item.active{color:var(--accent);background:#facc151a}.nav-item.active:before{content:"";background:var(--accent);border-radius:0 2px 2px 0;width:3px;position:absolute;top:4px;bottom:4px;left:0}.nav-icon{opacity:.8;flex-shrink:0;width:18px;height:18px}.nav-item.active .nav-icon{opacity:1}.btn{border-radius:var(--radius);cursor:pointer;white-space:nowrap;border:1px solid #0000;align-items:center;gap:6px;padding:7px 14px;font-family:inherit;font-size:13.5px;font-weight:500;text-decoration:none;transition:all .15s;display:inline-flex}.btn-primary{background:var(--ink);color:#fff;border-color:var(--ink)}.btn-primary:hover{background:#333}.btn-accent{background:var(--accent);color:var(--accent-ink);font-weight:600}.btn-accent:hover{background:#f5c400}.btn-ghost{color:var(--ink-2);border-color:var(--border);background:0 0}.btn-ghost:hover{background:var(--surface-2);color:var(--ink)}.btn-danger{background:var(--danger-bg);color:var(--danger);border-color:#0000}.btn-danger:hover{background:#fecaca}.btn-sm{padding:5px 10px;font-size:12.5px}.btn-lg{padding:10px 20px;font-size:15px}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow)}.card-pad{padding:20px}.card-pad-sm{padding:14px 16px}.kpi-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow);padding:18px 20px;transition:transform .2s,box-shadow .2s;position:relative;overflow:hidden}.kpi-card:before{content:"";background:linear-gradient(90deg,var(--accent),transparent);opacity:0;height:3px;transition:opacity .2s;position:absolute;top:0;left:0;right:0}.kpi-card:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.kpi-card:hover:before{opacity:1}.kpi-value{color:var(--ink);margin:8px 0 4px;font-size:28px;font-weight:700;line-height:1}.kpi-label{color:var(--ink-3);text-transform:uppercase;letter-spacing:.05em}.kpi-delta,.kpi-label{font-size:12px;font-weight:500}.kpi-delta{align-items:center;gap:3px;margin-top:6px;display:flex}.kpi-delta.up{color:var(--ok)}.kpi-delta.down{color:var(--danger)}.table-wrap{border-radius:var(--radius-lg);border:1px solid var(--border);background:var(--surface);overflow-x:auto}table{border-collapse:collapse;width:100%;font-size:13.5px}th{text-align:left;letter-spacing:.06em;text-transform:uppercase;color:var(--ink-3);border-bottom:1px solid var(--border);background:var(--surface-2);white-space:nowrap;padding:10px 16px;font-size:11px;font-weight:600}td{border-bottom:1px solid var(--border-soft);color:var(--ink-2);vertical-align:middle;padding:12px 16px}tr:last-child td{border-bottom:none}tr:hover td{background:var(--surface-2)}.badge{border-radius:99px;align-items:center;gap:4px;padding:3px 8px;font-size:11.5px;font-weight:600;display:inline-flex}.badge-ok{background:var(--ok-bg);color:var(--ok)}.badge-warn{background:var(--warn-bg);color:var(--warn)}.badge-danger{background:var(--danger-bg);color:var(--danger)}.badge-info{background:var(--info-bg);color:var(--info)}.badge-neutral{background:var(--surface-2);color:var(--ink-3)}.badge-accent{color:#854d0e;background:#fef9c3}.form-label{color:var(--ink-2);margin-bottom:5px;font-size:12.5px;font-weight:600;display:block}.form-input,.form-select,.form-textarea{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);width:100%;color:var(--ink);outline:none;padding:8px 12px;font-family:inherit;font-size:13.5px;transition:border-color .15s,box-shadow .15s}.form-input:focus,.form-select:focus,.form-textarea:focus{border-color:var(--ink);box-shadow:0 0 0 3px #facc1526}.page-header{justify-content:space-between;align-items:flex-start;gap:16px;margin-bottom:24px;display:flex}.page-title{color:var(--ink);font-size:20px;font-weight:700}.page-subtitle{color:var(--ink-3);margin-top:2px;font-size:13px}@keyframes fadeRise{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes shimmer{0%{background-position:-400px 0}to{background-position:400px 0}}@keyframes pulse-ring{0%{opacity:.8;transform:scale(1)}to{opacity:0;transform:scale(1.8)}}@keyframes laser-scan{0%{top:10%}to{top:90%}}.fade-rise{animation:fadeRise .35s both}.shimmer-bar{background:linear-gradient(90deg,var(--border) 25%,var(--surface-2) 50%,var(--border) 75%);background-size:800px 100%;animation:shimmer 1.8s infinite}.text-ok{color:var(--ok)}.text-warn{color:var(--warn)}.text-danger{color:var(--danger)}.text-info{color:var(--info)}.text-muted{color:var(--ink-3)}.text-accent{color:var(--warn)}.mono{font-family:IBM Plex Mono,monospace;font-size:12.5px}.divider{background:var(--border);height:1px;margin:0}.grid-cols-4{grid-template-columns:repeat(4,1fr);gap:16px;display:grid}.grid-cols-3{grid-template-columns:repeat(3,1fr);gap:16px;display:grid}.grid-cols-2{grid-template-columns:repeat(2,1fr);gap:16px;display:grid}@media (max-width:1200px){.grid-cols-4{grid-template-columns:repeat(2,1fr)}}@media (max-width:900px){.sidebar{display:none}.page-content{padding:16px}.grid-cols-2,.grid-cols-3,.grid-cols-4{grid-template-columns:1fr}}@property --tw-border-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-outline-style{syntax:"*";inherits:false;initial-value:solid}@property --tw-ease{syntax:"*";inherits:false}