@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700&family=IBM+Plex+Sans+Thai:wght@400;500;600;700&display=swap";:root{--red-50: #fef2f2;--red-100: #fee2e2;--red-200: #fecaca;--red-300: #fca5a5;--red-400: #f87171;--red-500: #ef4444;--red-600: #dc2626;--red-700: #b91c1c;--red-800: #991b1b;--red-900: #7f1d1d;--gold-50: #fefce8;--gold-100: #fef9c3;--gold-200: #fef08a;--gold-300: #fde047;--gold-400: #facc15;--gold-500: #eab308;--gold-600: #ca8a04;--gold-700: #a16207;--blue-50: #eff6ff;--blue-100: #dbeafe;--blue-200: #bfdbfe;--blue-300: #93c5fd;--blue-400: #60a5fa;--blue-500: #3b82f6;--blue-600: #2563eb;--blue-700: #1d4ed8;--slate-0: #ffffff;--slate-25: #fcfcfd;--slate-50: #f8fafc;--slate-100: #f1f5f9;--slate-200: #e2e8f0;--slate-300: #cbd5e1;--slate-400: #94a3b8;--slate-500: #64748b;--slate-600: #475569;--slate-700: #334155;--slate-800: #1e293b;--slate-900: #0f172a;--bg: var(--slate-50);--bg-elevated: var(--slate-0);--surface: var(--slate-0);--surface-subtle: var(--slate-25);--border: var(--slate-200);--border-strong: var(--slate-300);--text: var(--slate-800);--text-strong: var(--slate-900);--text-muted: var(--slate-500);--text-faint: var(--slate-400);--brand: var(--red-700);--brand-strong: var(--red-800);--brand-soft: var(--red-50);--brand-soft-border: var(--red-200);--accent: var(--gold-500);--accent-strong: var(--gold-600);--accent-soft: var(--gold-50);--accent-soft-border: var(--gold-200);--secondary: var(--blue-600);--secondary-soft: var(--blue-50);--secondary-soft-border: var(--blue-200);--success: #16a34a;--success-soft: #f0fdf4;--success-border: #bbf7d0;--warning: var(--gold-600);--warning-soft: var(--gold-50);--warning-border: var(--gold-200);--danger: var(--red-600);--danger-soft: var(--red-50);--danger-border: var(--red-200);--info: var(--blue-600);--info-soft: var(--blue-50);--info-border: var(--blue-200);--neutral: var(--slate-500);--neutral-soft: var(--slate-100);--neutral-border: var(--slate-200);--radius-xs: 4px;--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px;--radius-full: 9999px;--shadow-xs: 0 1px 2px 0 rgb(15 23 42 / .05);--shadow-sm: 0 1px 3px 0 rgb(15 23 42 / .07), 0 1px 2px -1px rgb(15 23 42 / .07);--shadow-md: 0 4px 12px -2px rgb(15 23 42 / .08), 0 2px 4px -2px rgb(15 23 42 / .06);--shadow-lg: 0 12px 28px -4px rgb(15 23 42 / .12), 0 4px 8px -4px rgb(15 23 42 / .08);--shadow-xl: 0 24px 48px -8px rgb(15 23 42 / .18);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--space-10: 40px;--space-12: 48px;--sidebar-w: 248px;--topbar-h: 60px;--font-sans: "Inter", "IBM Plex Sans Thai", "Noto Sans Thai", "Segoe UI", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", ui-monospace, monospace;--text-2xs: .6875rem;--text-xs: .75rem;--text-sm: .8125rem;--text-base: .9375rem;--text-md: 1rem;--text-lg: 1.125rem;--text-xl: 1.375rem;--text-2xl: 1.75rem;--text-3xl: 2.25rem;--leading-tight: 1.25;--leading-normal: 1.5;--leading-relaxed: 1.65;--weight-normal: 400;--weight-medium: 500;--weight-semibold: 600;--weight-bold: 700;--ease: cubic-bezier(.4, 0, .2, 1);--ease-out: cubic-bezier(.16, 1, .3, 1);--dur-fast: .12s;--dur: .18s;--dur-slow: .28s}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}html,body,#root{height:100%}body{font-family:var(--font-sans);font-size:var(--text-base);line-height:var(--leading-normal);color:var(--text);background:var(--bg);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}button,input,select,textarea{font-family:inherit;font-size:inherit;color:inherit}button{cursor:pointer;border:none;background:none}a{color:inherit;text-decoration:none}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{color:var(--text-strong);line-height:var(--leading-tight);font-weight:var(--weight-semibold)}::-webkit-scrollbar{width:10px;height:10px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--slate-300);border-radius:var(--radius-full);border:2px solid var(--bg)}::-webkit-scrollbar-thumb:hover{background:var(--slate-400)}::selection{background:var(--red-200);color:var(--red-900)}.app-shell{display:grid;grid-template-columns:var(--sidebar-w) 1fr;min-height:100vh}.app-main{display:flex;flex-direction:column;min-width:0}.app-content{padding:var(--space-6);flex:1;max-width:1480px;width:100%}.page-header{display:flex;align-items:flex-start;justify-content:space-between;gap:var(--space-4);margin-bottom:var(--space-6);flex-wrap:wrap}.page-title{font-size:var(--text-xl);font-weight:var(--weight-bold);letter-spacing:-.01em}.page-subtitle{font-size:var(--text-sm);color:var(--text-muted);margin-top:2px}.grid{display:grid;gap:var(--space-4)}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}.grid-auto{grid-template-columns:repeat(auto-fill,minmax(280px,1fr))}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.items-start{align-items:flex-start}.justify-between{justify-content:space-between}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.flex-wrap{flex-wrap:wrap}.flex-1{flex:1}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.text-xs{font-size:var(--text-xs)}.text-sm{font-size:var(--text-sm)}.text-base{font-size:var(--text-base)}.text-lg{font-size:var(--text-lg)}.text-muted{color:var(--text-muted)}.text-faint{color:var(--text-faint)}.text-strong{color:var(--text-strong);font-weight:var(--weight-semibold)}.text-center{text-align:center}.font-medium{font-weight:var(--weight-medium)}.font-semibold{font-weight:var(--weight-semibold)}.font-bold{font-weight:var(--weight-bold)}.mono{font-family:var(--font-mono)}.divider{height:1px;background:var(--border);border:none;margin:var(--space-4) 0}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stack-sm>*+*{margin-top:var(--space-2)}.stack>*+*{margin-top:var(--space-4)}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.app-shell,.grid-2,.grid-3,.grid-4{grid-template-columns:1fr}}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes scaleIn{0%{opacity:0;transform:scale(.96)}to{opacity:1;transform:scale(1)}}.fade-in{animation:fadeIn var(--dur) var(--ease) both}.slide-up{animation:slideUp var(--dur-slow) var(--ease-out) both}.scale-in{animation:scaleIn var(--dur) var(--ease-out) both}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm)}.card-pad{padding:var(--space-5)}.card-pad-sm{padding:var(--space-4)}.card-header{display:flex;align-items:center;justify-content:space-between;gap:var(--space-3);padding:var(--space-4) var(--space-5);border-bottom:1px solid var(--border)}.card-header h3{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-strong);text-transform:uppercase;letter-spacing:.03em}.card-body{padding:var(--space-5)}.kpi{display:flex;flex-direction:column;gap:var(--space-2);padding:var(--space-5);background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);position:relative;overflow:hidden;transition:box-shadow var(--dur) var(--ease),transform var(--dur) var(--ease)}.kpi:hover{box-shadow:var(--shadow-md);transform:translateY(-1px)}.kpi-label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em}.kpi-value{font-size:var(--text-2xl);font-weight:var(--weight-bold);color:var(--text-strong);letter-spacing:-.02em;line-height:1.1}.kpi-icon{position:absolute;top:var(--space-4);right:var(--space-4);width:36px;height:36px;border-radius:var(--radius-md);display:grid;place-items:center}.kpi-icon.brand{background:var(--brand-soft);color:var(--brand)}.kpi-icon.accent{background:var(--accent-soft);color:var(--accent-strong)}.kpi-icon.secondary{background:var(--secondary-soft);color:var(--secondary)}.kpi-icon.neutral{background:var(--neutral-soft);color:var(--neutral)}.kpi-sub{font-size:var(--text-xs);color:var(--text-muted)}.badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:2px var(--space-2);border-radius:var(--radius-full);font-size:var(--text-2xs);font-weight:var(--weight-semibold);line-height:1.5;white-space:nowrap;border:1px solid transparent}.badge-brand{background:var(--brand-soft);color:var(--red-700);border-color:var(--brand-soft-border)}.badge-accent{background:var(--accent-soft);color:var(--accent-strong);border-color:var(--accent-soft-border)}.badge-secondary{background:var(--secondary-soft);color:var(--secondary);border-color:var(--secondary-soft-border)}.badge-success{background:var(--success-soft);color:var(--success);border-color:var(--success-border)}.badge-warning{background:var(--warning-soft);color:var(--warning);border-color:var(--warning-border)}.badge-danger{background:var(--danger-soft);color:var(--danger);border-color:var(--danger-border)}.badge-info{background:var(--info-soft);color:var(--info);border-color:var(--info-border)}.badge-neutral{background:var(--neutral-soft);color:var(--neutral);border-color:var(--neutral-border)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-2);padding:var(--space-2) var(--space-4);border-radius:var(--radius-md);font-size:var(--text-sm);font-weight:var(--weight-medium);line-height:1.4;border:1px solid transparent;transition:all var(--dur-fast) var(--ease);white-space:nowrap}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--brand);color:#fff;box-shadow:var(--shadow-xs)}.btn-primary:hover:not(:disabled){background:var(--brand-strong);box-shadow:var(--shadow-sm)}.btn-secondary{background:var(--surface);color:var(--text-strong);border-color:var(--border-strong)}.btn-secondary:hover:not(:disabled){background:var(--slate-50);border-color:var(--slate-400)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover:not(:disabled){background:var(--slate-100);color:var(--text-strong)}.btn-success{background:var(--success);color:#fff}.btn-success:hover:not(:disabled){background:#15803d}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){background:var(--red-700)}.btn-warning{background:var(--warning);color:#fff}.btn-warning:hover:not(:disabled){background:var(--accent-strong)}.btn-sm{padding:var(--space-1) var(--space-3);font-size:var(--text-xs)}.btn-icon{padding:var(--space-2);width:34px;height:34px}.progress{height:6px;background:var(--slate-100);border-radius:var(--radius-full);overflow:hidden}.progress-bar{height:100%;border-radius:var(--radius-full);background:var(--secondary);transition:width var(--dur-slow) var(--ease)}.progress-bar.brand{background:var(--brand)}.progress-bar.accent{background:var(--accent)}.progress-bar.success{background:var(--success)}.progress-bar.warning{background:var(--warning)}.avatar{display:inline-flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-full);color:#fff;font-size:var(--text-xs);font-weight:var(--weight-semibold);flex-shrink:0;box-shadow:var(--shadow-xs)}.avatar-sm{width:26px;height:26px;font-size:var(--text-2xs)}.avatar-lg{width:44px;height:44px;font-size:var(--text-sm)}.avatar-stack{display:flex}.avatar-stack>*+*{margin-left:-8px;box-shadow:0 0 0 2px var(--surface)}.field{display:flex;flex-direction:column;gap:var(--space-1)}.field-label{font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-muted)}.input,.select,.textarea{width:100%;padding:var(--space-2) var(--space-3);border:1px solid var(--border-strong);border-radius:var(--radius-md);background:var(--surface);font-size:var(--text-sm);color:var(--text);transition:border-color var(--dur-fast) var(--ease),box-shadow var(--dur-fast) var(--ease)}.input:focus,.select:focus,.textarea:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.textarea{resize:vertical;min-height:72px}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;padding:var(--space-4);z-index:100;animation:fadeIn var(--dur) var(--ease)}.modal{background:var(--surface);border-radius:var(--radius-xl);box-shadow:var(--shadow-xl);width:100%;max-width:520px;max-height:90vh;overflow-y:auto;animation:scaleIn var(--dur) var(--ease-out)}.modal-lg{max-width:720px}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-5);border-bottom:1px solid var(--border)}.modal-header h2{font-size:var(--text-lg)}.modal-body{padding:var(--space-5);display:flex;flex-direction:column;gap:var(--space-4)}.modal-footer{display:flex;justify-content:flex-end;gap:var(--space-2);padding:var(--space-4) var(--space-5);border-top:1px solid var(--border);background:var(--surface-subtle);border-radius:0 0 var(--radius-xl) var(--radius-xl)}.table{width:100%;border-collapse:collapse;font-size:var(--text-sm)}.table th{text-align:left;padding:var(--space-3) var(--space-4);font-size:var(--text-2xs);font-weight:var(--weight-semibold);color:var(--text-muted);text-transform:uppercase;letter-spacing:.04em;border-bottom:1px solid var(--border);white-space:nowrap}.table td{padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);color:var(--text);vertical-align:middle}.table tr:last-child td{border-bottom:none}.table tbody tr{transition:background var(--dur-fast) var(--ease)}.table-hover tbody tr:hover{background:var(--slate-50)}.table-row-clickable{cursor:pointer}.sidebar{background:var(--slate-900);color:var(--slate-300);display:flex;flex-direction:column;position:sticky;top:0;height:100vh}.sidebar-brand{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-5);border-bottom:1px solid var(--slate-800)}.sidebar-brand-mark{width:38px;height:38px;border-radius:var(--radius-md);background:#fff;flex-shrink:0;box-shadow:var(--shadow-sm)}.sidebar-brand-name{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:#fff;line-height:1.2}.sidebar-brand-sub{font-size:var(--text-2xs);color:var(--slate-400)}.sidebar-nav{padding:var(--space-3);flex:1;overflow-y:auto}.sidebar-nav-section{font-size:var(--text-2xs);color:var(--slate-500);text-transform:uppercase;letter-spacing:.08em;padding:var(--space-3) var(--space-3) var(--space-1)}.nav-item{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);color:var(--slate-300);font-size:var(--text-sm);font-weight:var(--weight-medium);transition:all var(--dur-fast) var(--ease);cursor:pointer;margin-bottom:2px}.nav-item:hover{background:var(--slate-800);color:#fff}.nav-item.active{background:linear-gradient(90deg,var(--red-700),var(--red-800));color:#fff;box-shadow:var(--shadow-sm)}.nav-item.active .nav-item-icon{color:var(--gold-300)}.nav-item-icon{width:18px;height:18px;flex-shrink:0}.sidebar-footer{padding:var(--space-3);border-top:1px solid var(--slate-800)}.topbar{height:var(--topbar-h);background:var(--surface);border-bottom:1px solid var(--border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-6);position:sticky;top:0;z-index:20;gap:var(--space-4)}.topbar-left{display:flex;align-items:center;gap:var(--space-3);min-width:0}.topbar-right{display:flex;align-items:center;gap:var(--space-2)}.lang-toggle{display:inline-flex;background:var(--slate-100);border-radius:var(--radius-full);padding:2px}.lang-toggle button{padding:4px 10px;border-radius:var(--radius-full);font-size:var(--text-xs);font-weight:var(--weight-semibold);color:var(--text-muted);transition:all var(--dur-fast) var(--ease)}.lang-toggle button.active{background:var(--surface);color:var(--brand);box-shadow:var(--shadow-xs)}.user-switch{display:flex;align-items:center;gap:var(--space-2);padding:4px var(--space-2) 4px 4px;border-radius:var(--radius-full);border:1px solid var(--border);background:var(--surface);transition:border-color var(--dur-fast) var(--ease)}.user-switch:hover{border-color:var(--border-strong)}.user-switch select{border:none;background:transparent;font-size:var(--text-xs);font-weight:var(--weight-medium);color:var(--text-strong);cursor:pointer;padding-right:var(--space-1);max-width:160px}.user-switch select:focus{outline:none}.gate-pipeline{display:flex;align-items:stretch;gap:var(--space-2)}.gate-node{flex:1;border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3);background:var(--surface);position:relative;transition:all var(--dur) var(--ease)}.gate-node.approved{border-color:var(--success-border);background:var(--success-soft)}.gate-node.rejected{border-color:var(--danger-border);background:var(--danger-soft)}.gate-node.returned{border-color:var(--warning-border);background:var(--warning-soft)}.gate-node.active{border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.gate-connector{width:20px;display:grid;place-items:center;color:var(--slate-300);flex-shrink:0}.gate-connector.done{color:var(--success)}.org-node{border:1px solid var(--border);border-radius:var(--radius-md);padding:var(--space-3) var(--space-4);background:var(--surface);text-align:center;box-shadow:var(--shadow-xs);display:inline-flex;flex-direction:column;gap:2px;min-width:180px}.org-node.brand{border-color:var(--brand-soft-border);background:var(--brand-soft)}.org-node.accent{border-color:var(--accent-soft-border);background:var(--accent-soft)}.org-node.secondary{border-color:var(--secondary-soft-border);background:var(--secondary-soft)}.org-title{font-size:var(--text-sm);font-weight:var(--weight-semibold);color:var(--text-strong)}.org-sub{font-size:var(--text-2xs);color:var(--text-muted)}.empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-10) var(--space-4);text-align:center;color:var(--text-muted);gap:var(--space-3)}.empty-icon{width:40px;height:40px;color:var(--slate-300)}.dot{width:8px;height:8px;border-radius:50%;display:inline-block;flex-shrink:0}.list-row{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3) var(--space-4);border-bottom:1px solid var(--border);transition:background var(--dur-fast) var(--ease)}.list-row:last-child{border-bottom:none}.list-row:hover{background:var(--slate-50)}.clickable{cursor:pointer}.filter-bar{display:flex;align-items:center;gap:var(--space-3);flex-wrap:wrap;margin-bottom:var(--space-4)}.filter-bar .input,.filter-bar .select{width:auto;min-width:140px}.search-input{flex:1;min-width:200px}
