.auth-shell[data-v-7dd9e113]{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:24px;position:relative;overflow:hidden;background:radial-gradient(60% 60% at 50% 0%,rgba(96,165,250,.28),transparent 60%),radial-gradient(40% 40% at 90% 90%,rgba(37,99,235,.18),transparent 60%),linear-gradient(135deg,#eff6ff,#f5f7fa 60%,#e2ebf0)}.auth-shell[data-v-7dd9e113]:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;pointer-events:none;background-image:radial-gradient(circle at 20% 30%,rgba(37,99,235,.06) 0,transparent 2px),radial-gradient(circle at 70% 80%,rgba(37,99,235,.05) 0,transparent 2px),radial-gradient(circle at 40% 60%,rgba(37,99,235,.04) 0,transparent 2px);background-size:120px 120px,180px 180px,240px 240px}:root{--brand-700: #1D4ED8;--brand-600: #2563EB;--brand-500: #3B82F6;--brand-400: #60A5FA;--brand-300: #93C5FD;--brand-200: #BFDBFE;--brand-100: #DBEAFE;--brand-50: #EFF6FF;--brand-ink: #0F172A;--brand-slate: #64748B;--brand-cool: #E2EBF0;--brand-bg: #F5F7FA;--bg: #F5F7FA;--bg-subtle: #EEF2F7;--surface: #FFFFFF;--surface-2: #F8FAFC;--border: #E2EBF0;--border-strong: #CBD5E1;--divider: #EEF2F7;--text: #0F172A;--text-muted: #64748B;--text-light: #94A3B8;--success: #16A34A;--success-soft: #DCFCE7;--warning: #F59E0B;--warning-soft: #FEF3C7;--danger: #DC2626;--danger-soft: #FEE2E2;--info: #0EA5E9;--info-soft: #E0F2FE;--radius-sm: 8px;--radius: 12px;--radius-lg: 16px;--shadow-xs: 0 1px 2px rgba(15,23,42,.04);--shadow-sm: 0 2px 4px rgba(15,23,42,.05), 0 1px 2px rgba(15,23,42,.04);--shadow: 0 4px 14px rgba(15,23,42,.06);--shadow-lg: 0 12px 28px rgba(15,23,42,.1);--shadow-brand: 0 8px 24px rgba(37,99,235,.28);--topbar-h: 64px;--sidebar-w: 256px;--ease: cubic-bezier(.4,0,.2,1);--t: .18s;--t-fast: .12s}*{box-sizing:border-box;margin:0;padding:0}html,body,#app{height:100%}body{font-family:Sarabun,TH Sarabun Neue,Inter,Segoe UI,Tahoma,system-ui,-apple-system,sans-serif;background:var(--bg);color:var(--text);line-height:1.55;font-size:14px;-webkit-font-smoothing:antialiased}button{font-family:inherit;cursor:pointer;border:none;background:transparent;color:inherit}a{color:inherit;text-decoration:none}input,select,textarea{font-family:inherit}img,svg{display:block;max-width:100%}.btn{display:inline-flex;align-items:center;gap:6px;padding:9px 16px;border-radius:var(--radius-sm);font-size:13px;font-weight:600;border:1px solid transparent;transition:background var(--t-fast) var(--ease),color var(--t-fast) var(--ease),box-shadow var(--t-fast) var(--ease),transform var(--t-fast) var(--ease);white-space:nowrap}.btn:active:not(:disabled){transform:translateY(1px)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:linear-gradient(135deg,var(--brand-600),var(--brand-500));color:#fff;box-shadow:var(--shadow-brand)}.btn-primary:hover:not(:disabled){filter:brightness(1.05)}.btn-outline{background:var(--surface);color:var(--brand-600);border-color:var(--border-strong)}.btn-outline:hover:not(:disabled){background:var(--brand-50);border-color:var(--brand-400)}.btn-ghost{background:transparent;color:var(--text-muted)}.btn-ghost:hover{background:var(--bg-subtle);color:var(--text)}.btn-danger{background:var(--danger);color:#fff}.btn-danger:hover:not(:disabled){filter:brightness(.95)}.btn-sm{padding:5px 10px;font-size:12px}.btn-success{background:linear-gradient(135deg,#16a34a,#22c55e);color:#fff}.btn-success:hover:not(:disabled){filter:brightness(1.05)}.ico-btn{width:30px;height:30px;border-radius:8px;display:inline-flex;align-items:center;justify-content:center;background:var(--bg-subtle);color:var(--text-muted);border:1px solid transparent;transition:all .15s ease;cursor:pointer}.ico-btn:hover{background:var(--brand-50);color:var(--brand-700);border-color:var(--brand-200);transform:translateY(-1px)}.ico-btn.danger:hover{background:#fee2e2;color:#b91c1c;border-color:#fca5a5}.ico-btn.success:hover{background:#dcfce7;color:#15803d;border-color:#86efac}.ico-btn:active{transform:translateY(0)}.ico-btn+.ico-btn{margin-left:4px}.act-chip{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;font-size:11.5px;font-weight:600;border-radius:999px;background:var(--bg-subtle);color:var(--text-muted);border:1px solid transparent;cursor:pointer;transition:all .15s ease}.act-chip:hover{background:var(--brand-50);color:var(--brand-700);border-color:var(--brand-200)}.act-chip.danger{color:#b91c1c}.act-chip.danger:hover{background:#fee2e2;border-color:#fca5a5}.act-chip.success{color:#15803d}.act-chip.success:hover{background:#dcfce7;border-color:#86efac}.act-chip.warn{color:#b45309}.act-chip.warn:hover{background:#fef3c7;border-color:#fcd34d}.act-chip+.act-chip{margin-left:4px}table tbody tr{transition:background-color .12s ease}table tbody tr:hover{background:var(--brand-50)}.card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);box-shadow:var(--shadow-xs);margin-bottom:14px}.card-header{padding:14px 18px;border-bottom:1px solid var(--divider);display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.card-title{font-size:15px;font-weight:600}.card-body{padding:18px}.table-wrap{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius);overflow:auto;box-shadow:var(--shadow-xs)}table{width:100%;border-collapse:collapse;min-width:540px}thead{background:var(--surface-2)}th,td{padding:12px 16px;text-align:left;font-size:13px;border-bottom:1px solid var(--divider)}th{font-weight:600;font-size:11px;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px}tbody tr:hover{background:var(--brand-50)}tbody tr:last-child td{border-bottom:none}.field{display:flex;flex-direction:column;margin-bottom:14px}.field label{font-size:12px;font-weight:600;margin-bottom:6px;color:var(--text)}.field input,.field select,.field textarea{padding:10px 14px;border:1px solid var(--border);border-radius:var(--radius-sm);font-size:13px;background:var(--surface);color:var(--text);outline:none;font-family:inherit;transition:border-color var(--t) var(--ease),box-shadow var(--t) var(--ease)}.field input:focus,.field select:focus,.field textarea:focus{border-color:var(--brand-500);box-shadow:0 0 0 3px #3b82f626}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:12px}.form-grid .span-2{grid-column:span 2}@media (max-width: 700px){.form-grid{grid-template-columns:1fr}.form-grid .span-2{grid-column:auto}}.badge{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600}.badge-active{background:var(--success-soft);color:#15803d}.badge-inactive{background:var(--bg-subtle);color:var(--text-muted)}.badge-system{background:var(--brand-100);color:var(--brand-700)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:18px;gap:12px;flex-wrap:wrap}.page-title{font-size:22px;font-weight:700;letter-spacing:-.2px}.page-subtitle{font-size:13px;color:var(--text-muted);margin-top:2px}.flex{display:flex}.flex-between{display:flex;justify-content:space-between;align-items:center;gap:8px;flex-wrap:wrap}.gap-2{gap:8px}.gap-3{gap:12px}.text-muted{color:var(--text-muted)}.text-sm{font-size:12px}.mt-2{margin-top:8px}.mt-3{margin-top:12px}.mt-4{margin-top:16px}.toast{position:fixed;bottom:24px;right:24px;background:var(--success);color:#fff;padding:12px 20px;border-radius:var(--radius);font-size:13px;font-weight:500;box-shadow:var(--shadow-lg);z-index:300;transform:translateY(100px);opacity:0;transition:transform .28s var(--ease),opacity .28s var(--ease)}.toast.show{transform:translateY(0);opacity:1}.toast.error{background:var(--danger)}.page-hd{display:flex;justify-content:space-between;align-items:flex-end;gap:12px;flex-wrap:wrap;margin-bottom:16px}.page-hd h1{font-size:22px;font-weight:700;color:var(--text);letter-spacing:-.2px}.page-hd p{font-size:13px;color:var(--text-muted);margin-top:4px}.kpi-grid{display:grid;gap:12px;margin-bottom:16px}.kpi-4{grid-template-columns:repeat(4,1fr)}.kpi-3{grid-template-columns:repeat(3,1fr)}.kpi-5{grid-template-columns:repeat(5,1fr)}@media (max-width: 1100px){.kpi-4,.kpi-5{grid-template-columns:repeat(2,1fr)}.kpi-3{grid-template-columns:1fr}}@media (max-width: 540px){.kpi-4,.kpi-5{grid-template-columns:1fr}}.kbox{background:var(--surface);border:1px solid var(--border);border-radius:14px;padding:14px 16px;display:flex;flex-direction:column;gap:6px}.kbox .ki{width:30px;height:30px;border-radius:9px;display:inline-flex;align-items:center;justify-content:center}.kbox .kv{font-size:24px;font-weight:700;color:var(--brand-ink);letter-spacing:-.5px}.kbox .kl{font-size:12.5px;color:var(--text-muted)}.kbox .kt{font-size:11px;color:var(--success);display:inline-flex;align-items:center;gap:3px;margin-top:2px}.kbox .kt.down{color:var(--danger)}.kbox.t-blue .ki{background:#dbeafe;color:#2563eb}.kbox.t-green .ki{background:#dcfce7;color:#16a34a}.kbox.t-orange .ki{background:#ffedd5;color:#ea580c}.kbox.t-purple .ki{background:#ede9fe;color:#7c3aed}.kbox.t-rose .ki{background:#ffe4e6;color:#e11d48}.kbox.t-slate .ki{background:#f1f5f9;color:#475569}.box{background:var(--surface);border:1px solid var(--border);border-radius:14px;overflow:hidden;margin-bottom:14px}.box-hd{padding:14px 18px;border-bottom:1px solid var(--divider);display:flex;justify-content:space-between;align-items:center;gap:10px;flex-wrap:wrap}.box-hd h3{display:inline-flex;align-items:center;gap:8px;font-size:14.5px;font-weight:600;color:var(--text)}.box-hd .h-actions{display:flex;gap:6px;align-items:center;flex-wrap:wrap}.toolbar{padding:14px 16px;display:flex;align-items:center;gap:12px;border-bottom:1px solid var(--divider);flex-wrap:wrap;background:var(--surface)}.toolbar .search{flex:1;min-width:240px;max-width:460px;position:relative}.toolbar .search input{width:100%;height:36px;padding:0 12px 0 34px;border:1px solid var(--border);border-radius:10px;background:var(--bg-subtle);font-size:13px;outline:none}.toolbar .search input:focus{background:var(--surface);border-color:var(--brand-300);box-shadow:0 0 0 3px #60a5fa2e}.toolbar .search-ico{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--text-muted)}.chip{padding:6px 12px;font-size:12px;font-weight:500;color:var(--text-muted);background:var(--bg-subtle);border-radius:999px;transition:.15s}.chip:hover{background:var(--brand-100);color:var(--brand-700)}.chip.active{background:var(--brand-600);color:#fff}.dtbl{overflow:auto}.dtbl table{width:100%;border-collapse:collapse}.dtbl th{font-size:11px;font-weight:600;color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;padding:11px 14px;text-align:left;background:var(--surface-2);border-bottom:1px solid var(--divider);white-space:nowrap}.dtbl td{padding:12px 14px;font-size:13px;border-bottom:1px solid var(--divider)}.dtbl tbody tr:hover{background:#fafcff}.dtbl tbody tr:last-child td{border-bottom:0}.dtbl .mono{font-family:JetBrains Mono,Consolas,monospace;font-size:12px}.dtbl .muted{color:var(--text-muted)}.dtbl .right{text-align:right}.dtbl .empty{text-align:center;color:var(--text-muted);padding:28px}.tbl-foot{padding:12px 16px;font-size:12px;color:var(--text-muted);border-top:1px solid var(--divider);background:var(--surface-2)}.s-pill{display:inline-block;padding:3px 10px;border-radius:999px;font-size:11px;font-weight:600;white-space:nowrap}.s-done{background:#dcfce7;color:#15803d}.s-progress{background:#dbeafe;color:#1d4ed8}.s-wait{background:#fef3c7;color:#b45309}.s-cancel{background:#fee2e2;color:#b91c1c}.s-info{background:#e0f2fe;color:#0369a1}.s-purple{background:#ede9fe;color:#6d28d9}.link-btn{display:inline-flex;align-items:center;gap:3px;color:var(--brand-600);font-size:12.5px;font-weight:500;background:transparent}.link-btn:hover{text-decoration:underline}.seg-toggle{display:inline-flex;padding:3px;background:var(--bg-subtle);border-radius:10px}.seg-toggle button{padding:7px 14px;border-radius:8px;font-size:12.5px;color:var(--text-muted);font-weight:500}.seg-toggle button.on{background:var(--surface);color:var(--brand-700);box-shadow:0 1px 2px #0f172a14}.modal-backdrop{position:fixed;top:0;right:0;bottom:0;left:0;background:#0f172a73;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);display:flex;align-items:center;justify-content:center;z-index:200;padding:20px}.modal-box{background:var(--surface);border-radius:var(--radius-lg);max-width:640px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:var(--shadow-lg);border:1px solid var(--border);box-sizing:border-box}.modal-box *{box-sizing:border-box}.modal-head{padding:16px 20px;border-bottom:1px solid var(--divider);display:flex;justify-content:space-between;align-items:center;font-weight:600;font-size:16px}.modal-body{padding:20px;overflow-y:auto;overflow-x:hidden}.modal-foot{padding:14px 20px;border-top:1px solid var(--divider);display:flex;justify-content:flex-end;gap:8px}
