@import"https://fonts.googleapis.com/css2?family=Noto+Sans+Lao:wght@400;700&family=Noto+Sans+Thai:wght@400;700&family=Nunito:wght@400;600;700;800&family=Barlow:wght@400;500;600;700;800&display=swap";@import"https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&display=swap";@import"https://cdnjs.cloudflare.com/ajax/libs/font-awesome/6.4.0/css/all.min.css";@import"https://fonts.googleapis.com/css2?family=IBM+Plex+Sans+Thai:wght@400;500;600&display=swap";@import"https://fonts.googleapis.com/css2?family=Noto+Sans+Lao:wght@400;700&family=Noto+Sans+Thai:wght@400;700&display=swap";*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html,body{height:100%}@media(min-width:769px){html{zoom:90%}body{min-height:111.11vh}}@media(min-width:769px)and (max-width:1024px){html{zoom:80%}}:root{--accent: #1976d2;--accent-dark: #0d47a1;--accent-glow: rgba(25,118,210,.3);--accent-glow2: rgba(25,118,210,.1);--tb-bg: #ffffff;--tb-border: #e8eaed;--tb-text: #374151;--tb-sub: #9ca3af;--tb-icon: #6b7280;--tb-hover: #f3f4f6;--tb-h: 54px;--sb-bg: #ffffff;--sb-border: #e8eaed;--sb-hover: #f0f7ff;--sb-text: #4b5563;--sb-text-sub: #9ca3af;--sb-width: 235px;--sb-search-bg: #f9fafb;--content-bg: #f0f3f8;--shadow-sm: 0 1px 3px rgba(0,0,0,.08);--sb-icon: #1976d2;--sb-icon-active: #ffffff;--sb-icon-hover: #1976d2}body.dark,.app-root.dark{--tb-bg: #000000;--tb-border: #1f1f1f;--tb-text: #f5f5f5;--tb-sub: #d1d5db;--tb-icon: #f5f5f5;--tb-hover: #101010;--sb-bg: #000000;--sb-border: #1f1f1f;--sb-hover: #0d0d0d;--sb-text: #f5f5f5;--sb-text-sub: #d1d5db;--sb-search-bg: #050505;--content-bg: #000000;--shadow-sm: 0 1px 3px rgba(0,0,0,.5);--sb-icon: #60a5fa;--sb-icon-active: #ffffff;--sb-icon-hover: #93c5fd}body{font-family:Noto Sans Lao,Nunito,Barlow,sans-serif;background:var(--content-bg);min-height:100vh;transition:background .3s}.app-root{display:flex;flex-direction:column;min-height:100vh}.topbar{position:fixed;top:0;left:0;right:0;height:var(--tb-h);background:var(--tb-bg);border-bottom:1px solid var(--tb-border);display:flex;align-items:center;z-index:200;box-shadow:var(--shadow-sm);transition:background .3s,border-color .3s}.topbar-brand{width:var(--sb-width);min-width:var(--sb-width);display:flex;align-items:center;gap:11px;padding:0 18px;height:100%;border-right:1px solid var(--tb-border);flex-shrink:0;overflow:hidden;transition:width .28s,min-width .28s,border-color .3s}.brand-logo{width:36px;height:36px;flex-shrink:0;object-fit:contain;display:block}.brand-text{display:flex;flex-direction:column;line-height:1.2}.brand-name{font-size:13.5px;font-weight:800;color:#e53935;text-transform:uppercase;letter-spacing:.5px;white-space:nowrap;transition:opacity .2s,color .3s}.brand-sub{font-size:10px;font-weight:600;color:var(--accent);letter-spacing:.8px;text-transform:uppercase;white-space:nowrap;transition:opacity .2s,color .3s}.tb-hamburger{display:flex;align-items:center;justify-content:center;width:50px;height:100%;background:transparent!important;border:none!important;cursor:pointer;color:var(--tb-icon);font-size:17px;transition:color .2s;flex-shrink:0;box-shadow:none!important}.tb-hamburger:hover{color:var(--accent);background:transparent!important}.app-root.dark .tb-hamburger,.app-root.dark .tb-hamburger:hover{background:transparent!important;border:none!important}.topbar-right{flex:1;display:flex;align-items:center;justify-content:flex-end;padding:0 16px}.tb-actions{display:flex;align-items:center;gap:10px}.tb-dark-toggle{width:38px;height:38px;border-radius:50%;background:transparent!important;border:none!important;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:background .2s;flex-shrink:0;box-shadow:none!important}.tb-dark-toggle:hover{background:#ffffff1a!important}.tb-dark-toggle:active{transform:scale(.92)}.app-root.dark .tb-dark-toggle,.app-root.dark .tb-dark-toggle:hover{background:transparent!important;border-color:transparent!important}.app-root.dark .tb-dark-toggle:hover{background:#ffffff14!important}.app-root.dark .tb-dark-toggle i,.app-root.dark .tb-dark-toggle .dark-toggle-icon{color:gold!important;font-size:18px!important}.app-root:not(.dark) .tb-dark-toggle i,.app-root:not(.dark) .tb-dark-toggle .dark-toggle-icon{color:#e53935!important;font-size:18px!important}.tb-datetime{display:flex;align-items:center;gap:9px;padding:6px 4px}.tb-datetime i{font-size:13px;color:var(--tb-icon);flex-shrink:0}.tb-datetime-single{font-size:12.5px;font-weight:700;color:var(--tb-text);letter-spacing:.3px;font-family:Barlow,sans-serif;white-space:nowrap;transition:color .3s}.tb-notif-wrap{position:relative}.tb-notif-btn{position:relative;display:flex;align-items:center;justify-content:center;width:38px;height:38px;border-radius:50%;background:transparent!important;border:none!important;color:var(--tb-icon);font-size:18px;cursor:pointer;transition:color .2s;box-shadow:none!important}.tb-notif-btn:hover{color:var(--accent);background:transparent!important}.app-root.dark .tb-notif-btn,.app-root.dark .tb-notif-btn:hover{background:transparent!important;border:none!important}.notif-badge{position:absolute;top:-5px;right:-5px;background:#ef4444;color:#fff;font-size:9px;font-weight:800;min-width:17px;height:17px;border-radius:9px;display:flex;align-items:center;justify-content:center;padding:0 3px;border:2px solid var(--tb-bg);transition:border-color .3s}.tb-notif-panel{position:absolute;top:calc(100% + 8px);right:0;width:360px;background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:14px;box-shadow:0 8px 32px #00000024;z-index:300;overflow:hidden;transition:background .3s,border-color .3s}.notif-header{display:flex;align-items:center;gap:8px;padding:14px 16px 12px;border-bottom:1px solid var(--tb-border)}.notif-title{font-size:13px;font-weight:800;color:var(--tb-text);flex:1}.notif-count-tag{font-size:10px;font-weight:700;background:#ef4444;color:#fff;padding:2px 8px;border-radius:20px}.notif-mark-all{font-size:11px;font-weight:600;color:var(--accent);background:none;border:none;cursor:pointer;font-family:inherit;padding:3px 8px;border-radius:6px;transition:background .15s}.notif-mark-all:hover{background:var(--sb-hover)}.notif-list{max-height:380px;overflow-y:auto}.notif-list::-webkit-scrollbar{width:3px}.notif-list::-webkit-scrollbar-thumb{background:var(--sb-border);border-radius:3px}.notif-item{display:flex;align-items:flex-start;gap:11px;padding:12px 14px;border-bottom:1px solid var(--tb-border);cursor:pointer;transition:background .15s}.notif-item:last-child{border-bottom:none}.notif-item:hover{background:var(--tb-hover)}.notif-icon-wrap{width:36px;height:36px;border-radius:9px;flex-shrink:0;display:flex;align-items:center;justify-content:center;font-size:15px}.notif-red{background:#ef44441f;color:#ef4444}.notif-blue{background:#1976d21f;color:#1976d2}.notif-amber{background:#f59e0b1f;color:#d97706}.notif-green{background:#16a34a1f;color:#16a34a}.notif-purple{background:#7c3aed1f;color:#7c3aed}.notif-body{flex:1;min-width:0}.notif-item-title{font-size:12.5px;font-weight:700;color:var(--tb-text);transition:color .3s;line-height:1.3;display:flex;align-items:center;gap:6px;flex-wrap:wrap}.notif-item-desc{font-size:11.5px;color:var(--tb-sub);margin-top:2px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.notif-item-dept{font-size:11px;color:var(--tb-sub);margin-top:3px;display:flex;align-items:center;gap:4px;opacity:.8}.notif-item-dept i{font-size:9px}.notif-item-time{font-size:10.5px;color:var(--tb-sub);margin-top:4px;display:flex;align-items:center;gap:4px;opacity:.7}.notif-item-time i{font-size:9px}.notif-warn-badge{display:inline-block;padding:1px 7px;border-radius:20px;background:#ef44441f;color:#ef4444;font-size:10px;font-weight:800;white-space:nowrap;flex-shrink:0}.notif-empty{display:flex;flex-direction:column;align-items:center;gap:8px;padding:32px 16px;color:var(--tb-sub);font-size:12.5px}.notif-empty i{font-size:28px;opacity:.4}.dropdown-enter-active,.dropdown-leave-active{transition:opacity .18s ease,transform .18s ease}.dropdown-enter-from,.dropdown-leave-to{opacity:0;transform:translateY(-6px)}.tb-profile-wrap{position:relative}.tb-profile-btn{display:flex;align-items:center;gap:9px;padding:5px 8px 5px 5px;background:transparent!important;border:none!important;border-radius:10px;cursor:pointer;transition:all .2s;font-family:inherit;box-shadow:none!important}.tb-profile-btn:hover{background:#ffffff14!important}.app-root.dark .tb-profile-btn,.app-root.dark .tb-profile-btn:hover{background:transparent!important;border:none!important}.app-root.dark .tb-profile-btn:hover{background:#ffffff0f!important}.tb-avatar{width:34px;height:34px;border-radius:50%;background:transparent!important;border:1.5px solid rgba(255,255,255,.25);display:flex;align-items:center;justify-content:center;flex-shrink:0}.tb-avatar i{font-size:15px;color:var(--tb-icon)}.tb-avatar-lg{width:40px;height:40px}.tb-avatar-lg i{font-size:18px}.app-root.dark .tb-avatar{background:transparent!important;border-color:#fff3!important}.app-root.dark .tb-avatar i{color:#e5e7eb!important}.tb-profile-info{display:flex;flex-direction:column;align-items:flex-start;line-height:1.25}.tb-profile-name{font-size:12.5px;font-weight:700;color:var(--tb-text);transition:color .3s}.tb-profile-role{font-size:10.5px;font-weight:600;color:var(--tb-sub);transition:color .3s}.tb-profile-arrow{font-size:10px;color:var(--tb-sub);transition:transform .25s,color .3s}.tb-profile-arrow.rotated{transform:rotate(180deg)}.tb-dropdown{position:absolute;top:calc(100% + 8px);right:0;width:220px;background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:12px;box-shadow:0 8px 32px #0000001f;z-index:300;overflow:hidden;transition:background .3s,border-color .3s}.tb-dropdown-header{display:flex;align-items:center;gap:10px;padding:14px 14px 12px}.tb-dd-name{font-size:13px;font-weight:700;color:var(--tb-text)}.tb-dd-email{font-size:11px;color:var(--tb-sub)}.tb-dropdown-divider{height:1px;background:var(--tb-border);margin:0 10px}.tb-dd-item{display:flex;align-items:center;gap:10px;width:100%;padding:10px 14px;background:none;border:none;cursor:pointer;font-size:12.5px;font-weight:600;color:var(--sb-text);font-family:inherit;transition:background .15s,color .15s;text-align:left}.tb-dd-item i{font-size:13px;width:16px;color:var(--tb-sub)}.tb-dd-item:hover{background:var(--tb-hover);color:var(--accent)}.tb-dd-item:hover i{color:var(--accent)}.tb-dd-logout,.tb-dd-logout i{color:#ef4444}.tb-dd-logout:hover{background:#ef444412;color:#ef4444}.layout{display:flex;flex:1;margin-top:var(--tb-h);min-height:calc(100vh - var(--tb-h))}.sidebar{width:var(--sb-width);min-width:var(--sb-width);background:var(--sb-bg);border-right:1px solid var(--sb-border);position:fixed;top:var(--tb-h);bottom:0;left:0;display:flex;flex-direction:column;overflow-y:auto;overflow-x:hidden;z-index:150;transition:width .28s ease,min-width .28s ease,left .3s ease,background .3s,border-color .3s;box-shadow:2px 0 12px #0000000a}.sidebar::-webkit-scrollbar{width:3px}.sidebar::-webkit-scrollbar-thumb{background:var(--sb-border);border-radius:3px}nav{flex:1;padding:4px 8px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:7px;cursor:pointer;transition:all .15s ease;color:var(--sb-text);font-size:13px;font-weight:600;white-space:nowrap;overflow:hidden;margin-bottom:2px;text-decoration:none;-webkit-user-select:none;user-select:none}.nav-item i{font-size:15px;width:20px;min-width:20px;text-align:center;flex-shrink:0;color:var(--sb-icon);transition:color .15s}.nav-item:hover{background:var(--sb-hover);color:var(--accent)}.nav-item:hover i{color:var(--sb-icon-hover)}.nav-item.active{background:var(--accent);color:#fff;box-shadow:0 3px 14px var(--accent-glow)}.nav-item.active i{color:var(--sb-icon-active)!important}.nav-label{flex:1}.nav-parent .nav-arrow{font-size:10px;color:var(--sb-text-sub);transition:transform .25s,color .15s;flex-shrink:0}.nav-parent .nav-arrow.rotated{transform:rotate(90deg)}.nav-parent:hover .nav-arrow,.nav-parent.has-active{color:var(--accent)}.nav-parent.has-active>i{color:var(--accent)!important}.submenu-wrap{overflow:hidden}.nav-child{padding:8px 12px 8px 42px;font-size:12.5px}.nav-child i{font-size:13px}.submenu-enter-active{transition:max-height .25s ease,opacity .2s ease;max-height:300px}.submenu-leave-active{transition:max-height .2s ease,opacity .15s ease}.submenu-enter-from,.submenu-leave-to{max-height:0;opacity:0}.submenu-enter-to,.submenu-leave-from{max-height:300px;opacity:1}.sb-divider{height:1px;background:var(--sb-border);margin:8px 12px;transition:background .3s}.sb-bottom{padding:0;flex-shrink:0}.sb-version{text-align:center;font-size:10px;color:var(--sb-text-sub);padding:6px 0 10px;letter-spacing:.5px}.content-wrap{flex:1;margin-left:var(--sb-width);min-height:calc(100vh - var(--tb-h));display:flex;flex-direction:column;position:relative;overflow:hidden;transition:margin-left .28s ease;background:var(--content-bg)}.content-container{flex:1;padding:24px;min-height:calc(100vh - var(--tb-h))}.mobile-overlay{display:none;position:fixed;inset:0;background:#0006;z-index:140}.sb-collapsed .sidebar{width:58px;min-width:58px}.sb-collapsed .content-wrap{margin-left:58px}.sb-collapsed .topbar-brand{width:58px;min-width:58px}.sb-collapsed .brand-name{opacity:0;width:0;overflow:hidden}.sb-collapsed .nav-label,.sb-collapsed .dark-label,.sb-collapsed .sb-version,.sb-collapsed .switch,.sb-collapsed .nav-arrow,.sb-collapsed .submenu-wrap,.sb-collapsed .sb-divider{display:none}.sb-collapsed .nav-item{justify-content:center;padding:10px 0}.sb-collapsed .nav-item i{width:auto;font-size:17px}.sb-collapsed .nav-child{padding:10px 0}@media(max-width:768px){html{zoom:1!important}.topbar-brand{display:none}.tb-hamburger{border-right:none}.sidebar{left:-100%;box-shadow:none;width:var(--sb-width)!important;min-width:var(--sb-width)!important}.sidebar._open{left:0;box-shadow:4px 0 24px #00000026}.mobile-overlay{display:block}.content-wrap{margin-left:0!important;width:100%}.tb-datetime{display:none}.tb-notif-panel{width:300px;right:-60px}.drawer{max-width:100%!important}}.app-root.dark .nav-item.active i{color:var(--sb-icon-active)!important}.app-root.dark .nav-parent.has-active>i{color:var(--accent)!important}.app-root.dark{background:#000!important;color:#f5f5f5!important}.app-root.dark body,.app-root.dark *{background-color:inherit!important;color:inherit!important}.app-root.dark .layout,.app-root.dark .content-wrap,.app-root.dark .content-container,.app-root.dark main{background:#000!important;color:#f5f5f5!important}.app-root.dark .nav-item i{color:var(--sb-icon)!important}.app-root.dark .nav-item:hover i{color:var(--sb-icon-hover)!important}.app-root.dark .nav-item.active i{color:#fff!important}.app-root.dark .notif-red i{color:#ef4444!important}.app-root.dark .notif-amber i{color:#d97706!important}.app-root.dark .notif-blue i{color:#1976d2!important}.app-root.dark .notif-green i{color:#16a34a!important}.app-root.dark .notif-purple i{color:#7c3aed!important}.app-root.dark .tb-dd-logout i{color:#ef4444!important}.app-root.dark .tb-dd-item:hover i{color:var(--accent)!important}.app-root.dark input[type=text],.app-root.dark input[type=email],.app-root.dark input[type=password],.app-root.dark input[type=number],.app-root.dark input[type=date],.app-root.dark input[type=time],.app-root.dark input[type=search],.app-root.dark textarea,.app-root.dark select{background:#1a1a1a!important;color:#fff!important;border-color:#333!important}.app-root.dark input::placeholder,.app-root.dark textarea::placeholder{color:#9ca3af!important}.app-root.dark table{background:#050505!important;color:#fff!important}.app-root.dark thead{background:#000!important;color:#fff!important}.app-root.dark tbody tr{border-color:#333!important}.app-root.dark tbody tr:hover{background:#101010!important}.app-root.dark td,.app-root.dark th{color:#fff!important;border-color:#333!important}.app-root.dark .table-wrap{background:#050505!important}.app-root.dark button,.app-root.dark .btn{background:#3b82f6!important;color:#fff!important;border-color:#3b82f6!important}.app-root.dark button:hover,.app-root.dark .btn:hover{background:#2563eb!important;border-color:#2563eb!important}.app-root.dark button:disabled,.app-root.dark .btn:disabled{background:#4b5563!important}.app-root.dark .tb-hamburger,.app-root.dark .tb-hamburger:hover,.app-root.dark .tb-dark-toggle,.app-root.dark .tb-dark-toggle:hover,.app-root.dark .tb-notif-btn,.app-root.dark .tb-notif-btn:hover,.app-root.dark .tb-profile-btn,.app-root.dark .tb-profile-btn:hover{background:transparent!important;border-color:transparent!important;box-shadow:none!important}.app-root.dark .notif-mark-all,.app-root.dark .notif-mark-all:hover{background:transparent!important;border:none!important;color:var(--accent)!important}.app-root.dark .tb-dd-item,.app-root.dark .tb-dd-item:hover{background:transparent!important;border:none!important}.app-root.dark .tb-dd-item:hover{background:var(--tb-hover)!important}.app-root.dark .tb-dd-logout,.app-root.dark .tb-dd-logout:hover{background:transparent!important}.app-root.dark .tb-dd-logout:hover{background:#ef444412!important}.app-root.dark label{color:#d1d5db!important}.app-root.dark .card,.app-root.dark .form-group,.app-root.dark .tb-dropdown,.app-root.dark .tb-notif-panel,.app-root.dark .drawer,.app-root.dark .emp-dropdown{background:#050505!important;border-color:#222!important}.app-root.dark h1,.app-root.dark h2,.app-root.dark h3,.app-root.dark h4,.app-root.dark h5,.app-root.dark h6,.app-root.dark p{color:#f3f4f6!important}.app-root.dark .modal,.app-root.dark .dialog,.app-root.dark .popup,.app-root.dark [style*="background: white"],.app-root.dark [style*="background: #fff"],.app-root.dark [style*="background: #ffffff"],.app-root.dark [style*="background:#fff"],.app-root.dark [style*="background:#ffffff"],.app-root.dark [style*="background-color: #f"],.app-root.dark [style*="background: rgb(248"],.app-root.dark [style*="background: rgb(249"],.app-root.dark [style*="background: rgb(250"],.app-root.dark [style*="background: rgb(255"]{background:#050505!important;color:#f3f4f6!important}.app-root.dark [style*="color: white"],.app-root.dark [style*="color: #fff"],.app-root.dark [style*="color: #ffffff"]{color:#f3f4f6!important}.app-root.dark .content-container,.app-root.dark .page-wrapper,.app-root.dark main{background:#000!important;color:#f3f4f6!important}.app-root.dark span,.app-root.dark small{color:#e5e7eb!important}.app-root:not(.dark) input[type=text],.app-root:not(.dark) input[type=email],.app-root:not(.dark) input[type=password],.app-root:not(.dark) input[type=number],.app-root:not(.dark) input[type=date],.app-root:not(.dark) input[type=time],.app-root:not(.dark) input[type=search],.app-root:not(.dark) textarea,.app-root:not(.dark) select{background:#fff!important;color:#1f2937!important;border-color:#d1d5db!important}.app-root:not(.dark) input::placeholder,.app-root:not(.dark) textarea::placeholder{color:#9ca3af!important}.app-root:not(.dark) table{background:#fff!important;color:#1f2937!important}.app-root:not(.dark) thead{background:#f3f4f6!important;color:#1f2937!important}.app-root:not(.dark) tbody tr{border-color:#e5e7eb!important}.app-root:not(.dark) tbody tr:hover{background:#f9fafb!important}.app-root:not(.dark) td,.app-root:not(.dark) th{color:#1f2937!important;border-color:#e5e7eb!important}.app-root:not(.dark) h1,.app-root:not(.dark) h2,.app-root:not(.dark) h3,.app-root:not(.dark) h4,.app-root:not(.dark) h5,.app-root:not(.dark) h6,.app-root:not(.dark) p{color:#1f2937!important}.app-root:not(.dark) label{color:#374151!important}.app-root:not(.dark) span,.app-root:not(.dark) small{color:#4b5563!important}.app-root:not(.dark) .card,.app-root:not(.dark) .form-group,.app-root:not(.dark) .content-container{background:#f0f3f8!important;color:#1f2937!important}.drawer-overlay{position:fixed;top:var(--tb-h);left:0;right:0;bottom:0;background:#0000006b;display:flex;justify-content:flex-end;z-index:400}.drawer{width:100%;max-width:420px;height:100%;background:var(--tb-bg);border-left:1px solid var(--tb-border);display:flex;flex-direction:column;box-shadow:-6px 0 32px #0000002e;transition:background .3s,border-color .3s}.slide-right-enter-active{transition:transform .28s cubic-bezier(.4,0,.2,1),opacity .25s ease}.slide-right-leave-active{transition:transform .22s cubic-bezier(.4,0,.2,1),opacity .2s ease}.slide-right-enter-from,.slide-right-leave-to{transform:translate(100%);opacity:0}.drawer-header{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--tb-border);flex-shrink:0;transition:border-color .3s}.drawer-title{font-size:15px;font-weight:800;color:var(--tb-text);display:flex;align-items:center;gap:9px;transition:color .3s}.drawer-title i{color:#1976d2;font-size:15px}.drawer-close{width:32px;height:32px;border:none;background:var(--tb-hover);border-radius:8px;color:var(--tb-sub);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center;transition:background .15s,color .15s}.drawer-close:hover{color:var(--tb-text);background:var(--sb-border)}.drawer-body{flex:1;overflow-y:auto;overflow-x:hidden;padding:22px 20px;display:flex;flex-direction:column;gap:0}.drawer-body::-webkit-scrollbar{width:3px}.drawer-body::-webkit-scrollbar-thumb{background:var(--sb-border);border-radius:3px}.drawer-footer{padding:14px 20px;border-top:1px solid var(--tb-border);display:flex;gap:10px;justify-content:flex-end;flex-shrink:0;transition:border-color .3s}.field-group{display:flex;flex-direction:column;gap:6px;margin-bottom:18px}.field-label{font-size:12.5px;font-weight:700;color:var(--tb-text);display:flex;align-items:center;gap:5px;flex-wrap:wrap;transition:color .3s}.field-required{color:#dc2626;font-size:13px}.field-hint{font-size:11px;font-weight:500;color:var(--tb-sub)}.input-wrap{position:relative;display:flex;align-items:center}.field-input{width:100%;padding:10px 12px;border:1.5px solid var(--tb-border);border-radius:9px;font-size:13px;font-family:inherit;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:border-color .2s,box-shadow .2s,background .2s;box-sizing:border-box}.field-input--icon-l{padding-left:36px}.field-input--icon-r{padding-right:36px}.field-input:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a;background:var(--tb-bg)}.field-input::placeholder{color:var(--tb-sub);opacity:.65}.input-icon-left{position:absolute;left:11px;color:var(--tb-sub);font-size:13px;pointer-events:none;z-index:1}.input-icon-right{position:absolute;right:11px;color:var(--tb-sub);font-size:12px;pointer-events:none}.input-clear-btn{position:absolute;right:9px;background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:12px;padding:4px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:color .15s,background .15s}.input-clear-btn:hover{color:var(--tb-text);background:var(--tb-hover)}.emp-dropdown{position:absolute;top:calc(100% + 5px);left:0;right:0;border:1.5px solid var(--tb-border);border-radius:10px;background:var(--tb-bg);max-height:220px;overflow-y:auto;box-shadow:0 8px 24px #00000021;z-index:600}.emp-dropdown::-webkit-scrollbar{width:3px}.emp-dropdown::-webkit-scrollbar-thumb{background:var(--sb-border);border-radius:3px}.emp-option{width:100%;text-align:left;padding:10px 12px;border:none;background:none;cursor:pointer;display:flex;align-items:center;gap:8px;flex-wrap:wrap;font-size:13px;font-family:inherit;border-bottom:1px solid var(--tb-border);transition:background .15s}.emp-option:last-child{border-bottom:none}.emp-option:hover{background:var(--sb-hover)}.emp-code-badge{font-weight:700;color:#1976d2;background:#1976d217;padding:2px 8px;border-radius:5px;font-family:monospace;font-size:12px;flex-shrink:0}.emp-name{color:var(--tb-text);font-weight:600;flex:1;min-width:0}.emp-dept{font-size:11.5px;color:var(--tb-sub)}.emp-no-result{padding:16px 12px;text-align:center;color:var(--tb-sub);font-size:12.5px;display:flex;align-items:center;justify-content:center;gap:6px}.emp-selected-card{margin-top:8px;padding:12px 14px;background:#1976d20d;border:1.5px solid rgba(25,118,210,.18);border-radius:10px;display:flex;flex-direction:column;gap:6px}.emp-selected-row{display:flex;align-items:center;gap:10px;font-size:12.5px}.emp-selected-label{font-weight:700;color:var(--tb-sub);min-width:54px}.emp-selected-val{font-weight:600;color:var(--tb-text)}.emp-selected-code{font-family:monospace;color:#1976d2;background:#1976d214;padding:1px 8px;border-radius:5px}.error-msg{display:flex;align-items:center;gap:8px;padding:10px 14px;background:#dc262614;border:1px solid rgba(220,38,38,.22);border-radius:8px;color:#dc2626;font-size:12.5px;font-weight:600;margin-top:4px}.btn-save{display:flex;align-items:center;gap:7px;padding:9px 22px;background:#1976d2;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:background .2s,transform .15s;box-shadow:0 2px 8px #1976d240}.btn-save:hover:not(:disabled){background:#1565c0;transform:translateY(-1px)}.btn-save:disabled{opacity:.6;cursor:not-allowed;transform:none}.btn-cancel{padding:9px 18px;background:var(--tb-hover);color:var(--tb-sub);border:1.5px solid var(--tb-border);border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;font-family:inherit;transition:all .2s}.btn-cancel:hover:not(:disabled){color:var(--tb-text);background:var(--sb-border)}.btn-cancel:disabled{opacity:.6;cursor:not-allowed}.app-root.dark .drawer{background:#111!important;border-left-color:#2a2a2a!important}.app-root.dark .drawer-header{border-bottom-color:#2a2a2a!important}.app-root.dark .drawer-footer{border-top-color:#2a2a2a!important}.app-root.dark .drawer-title{color:#fff!important}.app-root.dark .drawer-close{background:#1a1a1a!important;color:#aaa!important}.app-root.dark .drawer-close:hover{background:#2a2a2a!important;color:#fff!important}.app-root.dark .field-input{background:#000!important;border-color:#333!important;color:#fff!important}.app-root.dark .field-input:focus{border-color:#1976d2!important;background:#0a0a0a!important}.app-root.dark .field-input::placeholder{color:#888!important}.app-root.dark .emp-dropdown{background:#111!important;border-color:#2a2a2a!important}.app-root.dark .emp-option{border-bottom-color:#222!important}.app-root.dark .emp-option:hover{background:#1a1a1a!important}.app-root.dark .emp-selected-card{background:#1976d214!important;border-color:#1976d240!important}.app-root.dark .input-clear-btn{color:#888!important}.app-root.dark .input-clear-btn:hover{color:#fff!important;background:#222!important}.app-root.dark .btn-cancel{background:#1a1a1a!important;color:#aaa!important;border-color:#333!important}.app-root.dark .btn-cancel:hover:not(:disabled){background:#2a2a2a!important;color:#fff!important}.app-root.dark .btn-save{background:#1976d2!important}.app-root.dark .btn-save:hover:not(:disabled){background:#1565c0!important}[data-v-8e14f28b]{margin:0;padding:0;box-sizing:border-box}.login-bg[data-v-8e14f28b]{min-height:100vh;width:100%;background-color:#fff;display:flex;align-items:center;justify-content:center;padding:20px;font-family:Inter,sans-serif}.login-card[data-v-8e14f28b]{width:100%;max-width:480px;background:#fff;border-radius:24px;padding:40px;border:1px solid #e5e7eb;position:relative;z-index:1;animation:fadeInUp-8e14f28b .6s ease-out;box-shadow:0 10px 25px -5px #0000001a,0 8px 10px -6px #0000001a}@keyframes fadeInUp-8e14f28b{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}.login-header[data-v-8e14f28b]{text-align:center;margin-bottom:32px}.logo-icon[data-v-8e14f28b]{width:70px;height:70px;background:linear-gradient(135deg,#667eea,#764ba2);border-radius:50%;display:flex;align-items:center;justify-content:center;margin:0 auto 16px;box-shadow:0 8px 20px #667eea4d}.logo-text[data-v-8e14f28b]{font-size:26px;font-weight:800;color:#fff;letter-spacing:1px;font-family:Inter,sans-serif}.login-title[data-v-8e14f28b]{font-size:32px;font-weight:800;background:linear-gradient(135deg,#667eea,#764ba2);-webkit-background-clip:text;background-clip:text;color:transparent;margin:0 0 8px;letter-spacing:4px}.login-sub[data-v-8e14f28b]{font-size:13px;color:#6b7280;font-weight:500}.login-form[data-v-8e14f28b]{display:flex;flex-direction:column;gap:20px}.field-group[data-v-8e14f28b]{display:flex;flex-direction:column;gap:8px}.field-label[data-v-8e14f28b]{font-size:13px;font-weight:600;color:#374151;display:flex;align-items:center;gap:8px}.field-label i[data-v-8e14f28b]{font-size:12px;color:#667eea}.input-wrap[data-v-8e14f28b]{position:relative}.field-input[data-v-8e14f28b]{width:100%;padding:12px 40px 12px 16px;border:2px solid #e5e7eb;border-radius:12px;font-size:14px;font-family:Inter,sans-serif;color:#1f2937;background:#f9fafb;outline:none;transition:all .3s ease;font-weight:500}.field-input[data-v-8e14f28b]:focus{border-color:#667eea;background:#fff;box-shadow:0 0 0 4px #667eea1a}.field-input[data-v-8e14f28b]::placeholder{color:#9ca3af;font-size:13px;font-weight:400}.toggle-pw[data-v-8e14f28b]{position:absolute;right:12px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#9ca3af;font-size:16px;padding:5px;transition:color .2s;z-index:2}.toggle-pw[data-v-8e14f28b]:hover{color:#667eea}.remember-row[data-v-8e14f28b]{display:flex;align-items:center;margin:-4px 0}.remember-label[data-v-8e14f28b]{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none}.custom-checkbox[data-v-8e14f28b]{width:18px;height:18px;border:2px solid #d1d5db;border-radius:5px;display:flex;align-items:center;justify-content:center;transition:all .2s ease;background:#f9fafb;flex-shrink:0}.custom-checkbox.checked[data-v-8e14f28b]{background:linear-gradient(135deg,#667eea,#764ba2);border-color:#667eea}.custom-checkbox i[data-v-8e14f28b]{font-size:10px;color:#fff}.custom-checkbox[data-v-8e14f28b]:hover{border-color:#667eea}.remember-text[data-v-8e14f28b]{font-size:13px;font-weight:500;color:#6b7280}.error-msg[data-v-8e14f28b]{display:flex;align-items:center;gap:10px;padding:12px 16px;background:linear-gradient(135deg,#fef2f2,#fff5f5);border-left:4px solid #ef4444;border-radius:12px;color:#dc2626;font-size:12px;font-weight:500;margin:4px 0}.error-msg i[data-v-8e14f28b]{font-size:16px}.btn-login[data-v-8e14f28b]{width:100%;padding:14px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:12px;font-size:15px;font-weight:700;font-family:Inter,sans-serif;cursor:pointer;display:flex;align-items:center;justify-content:center;gap:10px;transition:all .3s ease;box-shadow:0 8px 20px #667eea4d;margin-top:8px}.btn-login[data-v-8e14f28b]:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 12px 28px #667eea66}.btn-login[data-v-8e14f28b]:active:not(:disabled){transform:translateY(0)}.btn-login[data-v-8e14f28b]:disabled{opacity:.7;cursor:not-allowed;transform:none}@media(max-width:640px){.login-card[data-v-8e14f28b]{padding:32px 24px;border-radius:20px}.login-title[data-v-8e14f28b]{font-size:28px;letter-spacing:3px}.logo-icon[data-v-8e14f28b]{width:60px;height:60px}.logo-text[data-v-8e14f28b]{font-size:22px}.btn-login[data-v-8e14f28b]{padding:12px;font-size:14px}}@media(max-width:480px){.login-bg[data-v-8e14f28b]{padding:15px}.login-card[data-v-8e14f28b]{padding:28px 20px}.login-title[data-v-8e14f28b]{font-size:24px;letter-spacing:2px}.field-input[data-v-8e14f28b]{padding:10px 40px 10px 14px}}.page-wrap[data-v-125240ce]{font-family:SF Thonburi,system-ui,sans-serif;font-weight:400;padding:20px}.page-card[data-v-125240ce]{background:#fff;border:1px solid #e8eaed;border-radius:16px;box-shadow:0 1px 6px #0000000f;overflow:hidden}.card-header[data-v-125240ce]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;flex-wrap:wrap;gap:10px}.page-title[data-v-125240ce]{font-size:20px;font-weight:900;color:#111827}.card-divider[data-v-125240ce]{height:1px;background:#e8eaed}.filter-bar[data-v-125240ce]{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid #e8eaed;flex-wrap:wrap;background:#fafbfc}.search-wrap[data-v-125240ce]{position:relative;flex:1;min-width:220px}.search-icon[data-v-125240ce]{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:#9ca3af;font-size:13px;pointer-events:none}.search-input[data-v-125240ce]{width:100%;padding:8px 12px 8px 34px;border:1.5px solid #e5e7eb;border-radius:9px;font-size:13px;font-family:SF Thonburi,system-ui,sans-serif;color:#1a2035;background:#fff;outline:none;transition:border-color .2s,box-shadow .2s;box-sizing:border-box}.search-input[data-v-125240ce]:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a}.search-input[data-v-125240ce]::placeholder{color:#c4c9d4}.dept-select[data-v-125240ce]{padding:8px 30px 8px 12px;border:1.5px solid #e5e7eb;border-radius:9px;font-size:13px;font-weight:600;font-family:SF Thonburi,system-ui,sans-serif;color:#374151;background:#fff;outline:none;cursor:pointer;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24'%3E%3Cpath fill='%239ca3af' d='M7 10l5 5 5-5z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 10px center;min-width:130px}.dept-select[data-v-125240ce]:focus{border-color:#1976d2}.btn-clear[data-v-125240ce]{display:flex;align-items:center;gap:6px;padding:8px 14px;background:#f3f4f6;color:#6b7280;border:1.5px solid #e5e7eb;border-radius:9px;font-size:13px;font-weight:700;font-family:SF Thonburi,system-ui,sans-serif;cursor:pointer;transition:all .2s}.btn-clear[data-v-125240ce]:hover{background:#e5e7eb;color:#374151}.table-wrap[data-v-125240ce]{overflow-x:auto}.emp-table[data-v-125240ce]{width:100%;border-collapse:collapse;font-size:13px}.emp-table thead tr[data-v-125240ce]{background:#f8fafc;border-bottom:2px solid #e8eaed}.emp-table th[data-v-125240ce]{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:#9ca3af;white-space:nowrap;letter-spacing:.3px}.emp-table td[data-v-125240ce]{padding:11px 16px;border-bottom:1px solid #f3f4f6;color:#111827;font-size:14px;font-weight:600;white-space:nowrap}.emp-row:last-child td[data-v-125240ce]{border-bottom:none}.emp-row:hover td[data-v-125240ce]{background:#f0f7ff}.td-code[data-v-125240ce],.td-name[data-v-125240ce]{font-weight:700;color:#111827}.td-pos[data-v-125240ce]{color:#6b7280;font-size:13px;font-weight:500}.td-date[data-v-125240ce]{color:#9ca3af;font-size:12px;font-weight:400}.text-muted[data-v-125240ce]{color:#9ca3af}.status-badge[data-v-125240ce]{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11.5px;font-weight:700}.status-active[data-v-125240ce]{background:#16a34a1a;color:#16a34a}.status-resigned[data-v-125240ce]{background:#ef44441a;color:#dc2626}.created-by[data-v-125240ce]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:#1976d2;background:#1976d214;padding:2px 9px;border-radius:20px}.no-data[data-v-125240ce]{text-align:center;padding:48px 16px!important;color:#9ca3af;font-size:13px}.no-data i[data-v-125240ce]{font-size:32px;display:block;margin-bottom:8px;opacity:.4}.page-wrap[data-v-82b30245]{font-family:SF Thonburi,system-ui,sans-serif;font-weight:400;padding:20px}.page-card[data-v-82b30245]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:16px;box-shadow:0 1px 6px #0000000f;overflow:hidden}.card-header[data-v-82b30245]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;flex-wrap:wrap;gap:10px}.page-title[data-v-82b30245]{font-size:20px;font-weight:900;color:var(--tb-text);transition:color .3s}.btn-add[data-v-82b30245]{display:flex;align-items:center;gap:7px;padding:8px 16px;background:#1976d2;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s,transform .15s;box-shadow:0 2px 8px #1976d240}.btn-add[data-v-82b30245]:hover{background:#1565c0;transform:translateY(-1px)}.card-divider[data-v-82b30245]{height:1px;background:var(--tb-border)}.table-wrap[data-v-82b30245]{overflow-x:auto}.emp-table[data-v-82b30245]{width:100%;border-collapse:collapse;font-size:13px}.emp-table thead tr[data-v-82b30245]{background:var(--sb-search-bg);border-bottom:2px solid var(--tb-border)}.emp-table th[data-v-82b30245]{padding:12px 16px;text-align:left;font-size:13px;font-weight:600;color:var(--tb-sub);white-space:nowrap;letter-spacing:.3px}.emp-table td[data-v-82b30245]{padding:11px 16px;border-bottom:1px solid var(--tb-border);color:var(--tb-text);font-size:14px;font-weight:600;white-space:nowrap;transition:color .3s,border-color .3s,background .3s}.emp-row:last-child td[data-v-82b30245]{border-bottom:none}.emp-row:hover td[data-v-82b30245]{background:var(--sb-hover)}.td-code[data-v-82b30245]{font-weight:700;font-family:Barlow,monospace}.td-name[data-v-82b30245]{font-weight:700}.td-date[data-v-82b30245]{color:var(--tb-sub);font-size:12px}.text-muted[data-v-82b30245]{color:var(--tb-sub)}.username-badge[data-v-82b30245]{font-size:13px;font-weight:700}.created-by[data-v-82b30245]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:700;color:#1976d2;background:#1976d214;padding:2px 9px;border-radius:20px}.no-data[data-v-82b30245]{text-align:center;padding:48px 16px!important;color:var(--tb-sub);font-size:13px}.no-data i[data-v-82b30245]{font-size:32px;display:block;margin-bottom:8px;opacity:.4}.action-btns[data-v-82b30245]{display:flex;align-items:center;justify-content:center;gap:6px}.btn-delete[data-v-82b30245]{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:8px;background:#dc262614;color:#dc2626;border:1px solid rgba(220,38,38,.2);cursor:pointer;font-size:12px;transition:all .2s}.btn-delete[data-v-82b30245]:hover{background:#dc2626;color:#fff}.drawer-overlay[data-v-82b30245]{position:fixed;inset:54px 0 0;z-index:40;background:#00000059;display:flex;justify-content:flex-end}.drawer[data-v-82b30245]{width:100%;max-width:400px;background:var(--tb-bg);border-left:1px solid var(--tb-border);display:flex;flex-direction:column;height:100%;box-shadow:-4px 0 24px #00000026}.drawer-header[data-v-82b30245]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--tb-border)}.drawer-title[data-v-82b30245]{font-size:15px;font-weight:800;color:var(--tb-text);display:flex;align-items:center;gap:8px}.drawer-title i[data-v-82b30245]{color:#1976d2}.drawer-close[data-v-82b30245]{width:32px;height:32px;border:none;background:var(--tb-hover);border-radius:8px;color:var(--tb-sub);cursor:pointer;font-size:14px;display:flex;align-items:center;justify-content:center}.drawer-close[data-v-82b30245]:hover{color:var(--tb-text)}.drawer-body[data-v-82b30245]{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:16px}.drawer-footer[data-v-82b30245]{padding:16px 20px;border-top:1px solid var(--tb-border);display:flex;justify-content:flex-end;gap:10px}.field-group[data-v-82b30245]{display:flex;flex-direction:column;gap:6px}.field-label[data-v-82b30245]{font-size:12px;font-weight:700;color:var(--tb-text);display:flex;align-items:center;gap:5px;flex-wrap:wrap}.required[data-v-82b30245]{color:#dc2626}.input-wrap[data-v-82b30245]{position:relative}.input-icon-right[data-v-82b30245]{position:absolute;right:12px;top:50%;transform:translateY(-50%);color:var(--tb-sub);font-size:13px;pointer-events:none}.toggle-pw[data-v-82b30245]{position:absolute;right:10px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:13px;padding:4px}.toggle-pw[data-v-82b30245]:hover{color:var(--tb-text)}.field-input[data-v-82b30245]{width:100%;box-sizing:border-box;padding:9px 12px;border:1.5px solid var(--tb-border);border-radius:9px;font-size:13px;color:var(--tb-text);background:var(--sb-search-bg);outline:none;transition:border-color .2s,box-shadow .2s}.field-input[data-v-82b30245]:focus{border-color:#1976d2;box-shadow:0 0 0 3px #1976d21a;background:var(--tb-bg)}.field-input[data-v-82b30245]::placeholder{color:var(--tb-sub);opacity:.6}.emp-dropdown[data-v-82b30245]{position:absolute;top:calc(100% + 4px);left:0;right:0;border:1.5px solid var(--tb-border);border-radius:9px;background:var(--tb-bg);max-height:210px;overflow-y:auto;box-shadow:0 6px 20px #00000021;z-index:100}.emp-option[data-v-82b30245]{width:100%;text-align:left;padding:9px 12px;border:none;background:none;cursor:pointer;display:flex;align-items:baseline;gap:7px;font-size:13px;transition:background .15s;flex-wrap:wrap;border-bottom:1px solid var(--tb-border)}.emp-option[data-v-82b30245]:last-child{border-bottom:none}.emp-option[data-v-82b30245]:hover{background:var(--sb-hover)}.emp-option-code[data-v-82b30245]{font-weight:700;color:#1976d2;background:#1976d214;padding:1px 7px;border-radius:5px;font-family:monospace;font-size:12px;flex-shrink:0}.emp-option-name[data-v-82b30245]{color:var(--tb-text);font-weight:600}.emp-option-dept[data-v-82b30245]{font-size:11px;color:var(--tb-sub)}.emp-no-result[data-v-82b30245]{padding:14px 12px;text-align:center;color:var(--tb-sub);font-size:12px;display:flex;align-items:center;justify-content:center;gap:6px}.emp-selected-card[data-v-82b30245]{margin-top:6px;padding:10px 14px;background:#1976d20d;border:1.5px solid rgba(25,118,210,.18);border-radius:10px;display:flex;flex-direction:column;gap:5px}.emp-selected-row[data-v-82b30245]{display:flex;align-items:center;gap:8px;font-size:12px}.emp-selected-label[data-v-82b30245]{font-weight:700;color:var(--tb-sub);min-width:52px}.emp-selected-val[data-v-82b30245]{font-weight:600;color:var(--tb-text)}.emp-selected-code[data-v-82b30245]{font-family:monospace;color:#1976d2;background:#1976d214;padding:1px 8px;border-radius:5px}.error-msg[data-v-82b30245]{display:flex;align-items:center;gap:7px;padding:10px 12px;background:#dc262614;border:1px solid rgba(220,38,38,.2);border-radius:8px;color:#dc2626;font-size:12px;font-weight:600}.btn-save[data-v-82b30245]{display:flex;align-items:center;gap:7px;padding:9px 20px;background:#1976d2;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s,transform .15s;box-shadow:0 2px 8px #1976d240}.btn-save[data-v-82b30245]:hover:not(:disabled){background:#1565c0;transform:translateY(-1px)}.btn-save[data-v-82b30245]:disabled{opacity:.6;cursor:not-allowed}.btn-cancel[data-v-82b30245]{padding:9px 16px;background:var(--tb-hover);color:var(--tb-sub);border:1.5px solid var(--tb-border);border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;transition:all .2s}.btn-cancel[data-v-82b30245]:hover{color:var(--tb-text)}.confirm-overlay[data-v-82b30245]{position:fixed;inset:0;z-index:9998;background:#00000073;display:flex;align-items:center;justify-content:center;padding:20px}.confirm-box[data-v-82b30245]{background:var(--tb-bg);border-radius:16px;padding:28px 24px;max-width:360px;width:100%;box-shadow:0 8px 40px #00000040;text-align:center;border:1px solid var(--tb-border)}.confirm-icon[data-v-82b30245]{font-size:40px;color:#f59e0b;margin-bottom:12px}.confirm-msg[data-v-82b30245]{font-size:14px;font-weight:600;color:var(--tb-text);margin-bottom:20px;line-height:1.5}.confirm-actions[data-v-82b30245]{display:flex;gap:10px;justify-content:center}.btn-confirm-del[data-v-82b30245]{display:flex;align-items:center;gap:7px;padding:9px 20px;background:#dc2626;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;cursor:pointer;transition:background .2s}.btn-confirm-del[data-v-82b30245]:hover{background:#b91c1c}.toast[data-v-82b30245]{position:fixed;bottom:24px;left:50%;transform:translate(-50%);z-index:9999;color:#fff;padding:12px 24px;border-radius:12px;font-size:13px;font-weight:700;display:flex;align-items:center;gap:8px;box-shadow:0 4px 20px #00000026;animation:slideUp-82b30245 .3s ease}.toast-success[data-v-82b30245]{background:#16a34a}.toast-error[data-v-82b30245]{background:#dc2626}@keyframes slideUp-82b30245{0%{opacity:0;transform:translate(-50%) translateY(16px)}to{opacity:1;transform:translate(-50%) translateY(0)}}.page-wrap[data-v-97a714a8]{font-family:IBM Plex Sans Thai,system-ui,sans-serif;font-size:13px;padding:20px;display:flex;flex-direction:column;gap:16px}.form-card[data-v-97a714a8]{background:#fff;border:1px solid #e8eaed;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.header-bar[data-v-97a714a8]{background:#0f4c81;padding:12px 18px;display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:10px}.header-left[data-v-97a714a8]{display:flex;align-items:center;gap:10px}.header-icon[data-v-97a714a8]{width:36px;height:36px;background:#ffffff26;border-radius:8px;display:flex;align-items:center;justify-content:center;font-size:16px;flex-shrink:0}.header-title[data-v-97a714a8]{color:#fff;font-size:15px;font-weight:600}.header-sub[data-v-97a714a8]{color:#fff9;font-size:11px;margin-top:2px}.header-actions[data-v-97a714a8]{display:flex;gap:8px}.btn-outline[data-v-97a714a8]{padding:6px 13px;background:#ffffff1f;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:7px;font-size:12px;font-weight:500;font-family:inherit;cursor:pointer;transition:background .2s}.btn-outline[data-v-97a714a8]:hover{background:#ffffff38}.banner[data-v-97a714a8]{padding:10px 18px;font-size:13px;font-weight:500}.banner-success[data-v-97a714a8]{background:#16a34a14;color:#15803d;border-bottom:1px solid rgba(22,163,74,.15)}.banner-error[data-v-97a714a8]{background:#dc262612;color:#b91c1c;border-bottom:1px solid rgba(220,38,38,.15)}.form-body[data-v-97a714a8]{padding:16px 18px}.section-tag[data-v-97a714a8]{display:inline-block;font-size:11px;font-weight:600;color:#0f4c81;background:#0f4c8114;padding:3px 10px;border-radius:20px;margin-bottom:12px;letter-spacing:.3px}.grid-personal[data-v-97a714a8]{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.span-4[data-v-97a714a8]{grid-column:1 / 5}.grid-job-wrap[data-v-97a714a8]{display:block}.grid-job[data-v-97a714a8]{display:grid;grid-template-columns:repeat(6,1fr);gap:12px}.field[data-v-97a714a8]{display:flex;flex-direction:column;gap:4px}.field label[data-v-97a714a8]{font-size:11px;font-weight:600;color:#6b7280;text-transform:uppercase;letter-spacing:.4px}.req[data-v-97a714a8]{color:#dc2626}.field input[data-v-97a714a8],.field textarea[data-v-97a714a8]{padding:7px 10px;border:1px solid #e5e7eb;border-radius:7px;font-size:12px;font-family:inherit;color:#111827;background:#f9fafb;outline:none;transition:border-color .2s,box-shadow .2s,background .2s;width:100%;box-sizing:border-box}.field input[data-v-97a714a8]:focus,.field textarea[data-v-97a714a8]:focus{border-color:#0f4c81;box-shadow:0 0 0 3px #0f4c811a;background:#fff}.field input[type=date][data-v-97a714a8]{color:#111827}.field textarea[data-v-97a714a8]{resize:none;height:56px;line-height:1.5}.input-err[data-v-97a714a8]{border-color:#dc2626!important}.err-msg[data-v-97a714a8]{font-size:10px;color:#dc2626}.divider[data-v-97a714a8]{height:1px;background:#f3f4f6;margin:14px 0}.form-actions[data-v-97a714a8]{display:flex;justify-content:flex-end;margin-top:16px}.btn-add[data-v-97a714a8]{display:inline-flex;align-items:center;gap:8px;padding:10px 28px;background:#16a34a;color:#fff;border:none;border-radius:9px;font-size:14px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s,transform .15s}.btn-add[data-v-97a714a8]:hover{background:#15803d;transform:translateY(-1px)}.pending-card[data-v-97a714a8]{background:#fffbeb;border:1px solid #fcd34d;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.pending-bar[data-v-97a714a8]{padding:11px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #fde68a;gap:12px;flex-wrap:wrap}.pending-bar-left[data-v-97a714a8]{display:flex;align-items:center;gap:8px}.pending-title[data-v-97a714a8]{font-size:14px;font-weight:600;color:#92400e}.pending-badge[data-v-97a714a8]{background:#d97706}.btn-save[data-v-97a714a8]{display:inline-flex;align-items:center;gap:8px;padding:10px 24px;background:#0f4c81;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:600;font-family:inherit;cursor:pointer;transition:background .2s,transform .15s}.btn-save[data-v-97a714a8]:hover:not(:disabled){background:#1565c0;transform:translateY(-1px)}.btn-save[data-v-97a714a8]:disabled{background:#93c5fd;cursor:not-allowed;transform:none}.pending-row td[data-v-97a714a8]{background:#fffbeb}.pending-row:hover td[data-v-97a714a8]{background:#fef3c7}.btn-remove[data-v-97a714a8]{padding:3px 9px;background:transparent;color:#dc2626;border:1px solid #fca5a5;border-radius:6px;font-size:11px;cursor:pointer;font-family:inherit;transition:background .15s}.btn-remove[data-v-97a714a8]:hover{background:#fee2e2}.spinner[data-v-97a714a8]{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.4);border-top-color:#fff;border-radius:50%;animation:spin-97a714a8 .7s linear infinite}.spinner-dark[data-v-97a714a8]{border-color:#0f4c8133;border-top-color:#0f4c81}@keyframes spin-97a714a8{to{transform:rotate(360deg)}}.table-card[data-v-97a714a8]{background:#fff;border:1px solid #e8eaed;border-radius:14px;overflow:hidden;box-shadow:0 1px 4px #0000000f}.table-bar[data-v-97a714a8]{padding:11px 16px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid #f3f4f6}.table-bar-left[data-v-97a714a8]{display:flex;align-items:center;gap:8px}.table-icon[data-v-97a714a8]{font-size:15px}.table-title[data-v-97a714a8]{font-size:14px;font-weight:600;color:#111827}.count-badge[data-v-97a714a8]{background:#0f4c81;color:#fff;font-size:11px;font-weight:600;padding:2px 8px;border-radius:20px;min-width:22px;text-align:center}.table-wrap[data-v-97a714a8]{overflow-x:auto}.emp-table[data-v-97a714a8]{width:100%;border-collapse:collapse;font-size:12px;min-width:960px}.emp-table thead tr[data-v-97a714a8]{background:#f8fafc;border-bottom:2px solid #f3f4f6}.emp-table th[data-v-97a714a8]{padding:9px 12px;text-align:left;font-size:11px;font-weight:600;color:#9ca3af;white-space:nowrap;letter-spacing:.3px}.emp-table td[data-v-97a714a8]{padding:9px 12px;border-bottom:1px solid #f3f4f6;color:#111827;white-space:nowrap}.emp-row:last-child td[data-v-97a714a8]{border-bottom:none}.emp-row:hover td[data-v-97a714a8]{background:#f0f7ff}.td-num[data-v-97a714a8]{color:#9ca3af;font-size:11px}.td-code[data-v-97a714a8]{font-weight:600;color:#0f4c81}.td-name[data-v-97a714a8]{font-weight:600}.stat-pill[data-v-97a714a8]{display:inline-block;padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600;background:#f3f4f6;color:#6b7280}.empty-cell[data-v-97a714a8]{text-align:center;padding:40px 16px!important}.empty-state[data-v-97a714a8]{display:flex;flex-direction:column;align-items:center;gap:8px;color:#9ca3af;font-size:12px}.empty-icon[data-v-97a714a8]{font-size:32px;opacity:.3}@media(max-width:900px){.grid-personal[data-v-97a714a8]{grid-template-columns:repeat(2,1fr)}.span-4[data-v-97a714a8]{grid-column:1 / 3}.grid-job[data-v-97a714a8]{grid-template-columns:repeat(2,1fr)}}@media(max-width:540px){.grid-personal[data-v-97a714a8]{grid-template-columns:1fr}.span-4[data-v-97a714a8]{grid-column:1 / 2}.grid-job[data-v-97a714a8]{grid-template-columns:1fr}}.page-wrapper[data-v-3835b845]{padding:0;font-family:Nunito,Barlow,sans-serif;position:relative}.page-header[data-v-3835b845]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left[data-v-3835b845]{display:flex;align-items:center;gap:14px}.page-icon-wrap[data-v-3835b845]{width:44px;height:44px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--accent-glow);flex-shrink:0}.page-icon-wrap i[data-v-3835b845]{color:#fff;font-size:18px}.page-title[data-v-3835b845]{font-size:18px;font-weight:800;color:var(--tb-text);line-height:1.2;margin:0;transition:color .3s}.page-subtitle[data-v-3835b845]{font-size:12px;color:var(--tb-sub);margin:2px 0 0;transition:color .3s}.btn-add[data-v-3835b845]{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 14px var(--accent-glow);transition:all .2s}.btn-add[data-v-3835b845]:hover{background:var(--accent-dark);box-shadow:0 6px 20px var(--accent-glow);transform:translateY(-1px)}.btn-add i[data-v-3835b845]{font-size:12px}.card[data-v-3835b845]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;transition:background .3s,border-color .3s}.card-toolbar[data-v-3835b845]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--tb-border);flex-wrap:wrap;transition:border-color .3s}.toolbar-left[data-v-3835b845]{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.toolbar-right[data-v-3835b845]{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box[data-v-3835b845]{position:relative;min-width:200px;max-width:340px;flex:1}.search-icon[data-v-3835b845]{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tb-sub);font-size:13px;pointer-events:none}.search-input[data-v-3835b845]{width:100%;padding:8px 32px 8px 34px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s}.search-input[data-v-3835b845]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.search-input[data-v-3835b845]::placeholder{color:var(--tb-sub);font-weight:500}.search-clear[data-v-3835b845]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:12px;padding:3px;border-radius:4px;transition:color .2s,background .2s}.search-clear[data-v-3835b845]:hover{color:#ef4444;background:#ef444414}.result-chip[data-v-3835b845]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:20px;font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap}.result-chip i[data-v-3835b845]{font-size:11px}.count-chip[data-v-3835b845]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--sb-search-bg);border:1px solid var(--tb-border);border-radius:20px;font-size:12px;font-weight:600;color:var(--tb-sub);white-space:nowrap}.count-chip i[data-v-3835b845]{font-size:11px;opacity:.7}.table-wrapper[data-v-3835b845]{overflow-x:auto}.officers-table[data-v-3835b845]{width:100%;border-collapse:collapse;font-size:12.5px;min-width:820px}.officers-table thead tr[data-v-3835b845]{background:var(--sb-search-bg);border-bottom:2px solid var(--tb-border);transition:background .3s}.officers-table th[data-v-3835b845]{padding:11px 14px;text-align:left;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap;transition:color .3s}.th-num[data-v-3835b845]{width:44px;text-align:center}.officers-table tbody tr[data-v-3835b845]{border-bottom:1px solid var(--tb-border);transition:background .15s,border-color .3s}.officers-table tbody tr[data-v-3835b845]:last-child{border-bottom:none}.data-row[data-v-3835b845]:hover{background:var(--sb-hover)}.officers-table td[data-v-3835b845]{padding:11px 14px;color:var(--tb-text);vertical-align:middle;transition:color .3s}.td-num[data-v-3835b845]{text-align:center;font-size:11.5px;font-weight:700;color:var(--tb-sub)}.badge-code[data-v-3835b845]{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:6px;font-size:11.5px;font-weight:800;color:var(--accent);white-space:nowrap;font-family:Barlow,monospace;letter-spacing:.3px}.badge-code i[data-v-3835b845]{font-size:10px;opacity:.7}.cell-name[data-v-3835b845]{display:flex;align-items:center;gap:9px}.avatar-circle[data-v-3835b845]{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px var(--accent-glow)}.name-text[data-v-3835b845]{font-weight:700;color:var(--tb-text);transition:color .3s}.position-text[data-v-3835b845]{display:flex;align-items:center;gap:5px;font-size:12px;color:var(--tb-sub);font-weight:600}.pos-icon[data-v-3835b845]{font-size:10px;opacity:.6}.badge-dept[data-v-3835b845]{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#7c3aed14;border:1px solid rgba(124,58,237,.15);border-radius:6px;font-size:11.5px;font-weight:700;color:#7c3aed;white-space:nowrap}.badge-dept i[data-v-3835b845]{font-size:10px;opacity:.7}.badge-role[data-v-3835b845]{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:11px;font-weight:800;white-space:nowrap;letter-spacing:.3px}.role-admin[data-v-3835b845]{background:#ef44441a;color:#dc2626;border:1px solid rgba(239,68,68,.2)}.role-manager[data-v-3835b845]{background:#f59e0b1a;color:#d97706;border:1px solid rgba(245,158,11,.2)}.role-hr[data-v-3835b845]{background:#16a34a1a;color:#16a34a;border:1px solid rgba(22,163,74,.2)}.role-user[data-v-3835b845]{background:#0ea5e91a;color:#0284c7;border:1px solid rgba(14,165,233,.2)}.role-default[data-v-3835b845]{background:var(--sb-search-bg);color:var(--tb-sub);border:1px solid var(--tb-border)}.creator-tag[data-v-3835b845]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--tb-sub)}.creator-tag i[data-v-3835b845]{font-size:11px;opacity:.7}.date-cell[data-v-3835b845]{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--tb-sub);font-weight:600;white-space:nowrap}.date-icon[data-v-3835b845]{font-size:11px;opacity:.5}.sig-cell[data-v-3835b845]{display:flex;align-items:center}.sig-thumb[data-v-3835b845]{height:32px;max-width:90px;object-fit:contain;border-radius:5px;border:1px solid var(--tb-border);background:var(--sb-search-bg);padding:2px 4px;transition:border-color .2s,transform .2s;cursor:zoom-in}.sig-thumb[data-v-3835b845]:hover{border-color:var(--accent);transform:scale(1.08)}.cell-muted[data-v-3835b845]{color:var(--tb-sub);font-weight:600}.null-dash[data-v-3835b845]{color:var(--tb-border);font-size:14px;font-weight:400}.state-cell[data-v-3835b845]{padding:0!important}.state-content[data-v-3835b845]{display:flex;flex-direction:column;align-items:center;gap:10px;padding:52px 24px;color:var(--tb-sub);font-size:13px;font-weight:600}.empty-icon-wrap[data-v-3835b845]{width:52px;height:52px;border-radius:50%;background:var(--sb-search-bg);border:2px dashed var(--tb-border);display:flex;align-items:center;justify-content:center}.empty-icon-wrap i[data-v-3835b845]{font-size:20px;color:var(--tb-sub);opacity:.5}.empty-title[data-v-3835b845]{font-size:13.5px;font-weight:700;color:var(--tb-text)}.empty-sub[data-v-3835b845]{font-size:12px;color:var(--tb-sub)}.btn-add-empty[data-v-3835b845]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;margin-top:4px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;transition:background .2s}.btn-add-empty[data-v-3835b845]:hover{background:var(--accent-dark)}.spinner[data-v-3835b845]{width:28px;height:28px;border:3px solid var(--tb-border);border-top-color:var(--accent);border-radius:50%;animation:spin-3835b845 .7s linear infinite}@keyframes spin-3835b845{to{transform:rotate(360deg)}}.card-footer[data-v-3835b845]{padding:10px 16px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg);transition:border-color .3s,background .3s}.footer-info[data-v-3835b845]{font-size:12px;font-weight:600;color:var(--tb-sub)}.drawer-overlay[data-v-3835b845]{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400}.drawer-panel[data-v-3835b845]{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--tb-bg);border-left:1px solid var(--tb-border);box-shadow:-8px 0 40px #00000024;z-index:500;display:flex;flex-direction:column;transition:background .3s,border-color .3s;overflow:hidden}.drawer-header[data-v-3835b845]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--tb-border);flex-shrink:0;transition:border-color .3s}.drawer-header-left[data-v-3835b845]{display:flex;align-items:center;gap:12px}.drawer-icon[data-v-3835b845]{width:38px;height:38px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px var(--accent-glow);flex-shrink:0}.drawer-icon i[data-v-3835b845]{color:#fff;font-size:15px}.drawer-title[data-v-3835b845]{font-size:15px;font-weight:800;color:var(--tb-text);margin:0;line-height:1.2;transition:color .3s}.drawer-sub[data-v-3835b845]{font-size:11.5px;color:var(--tb-sub);margin:1px 0 0;transition:color .3s}.drawer-close[data-v-3835b845]{width:32px;height:32px;border-radius:8px;background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .2s;flex-shrink:0}.drawer-close[data-v-3835b845]:hover{background:#ef44441a;color:#ef4444}.drawer-body[data-v-3835b845]{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.drawer-body[data-v-3835b845]::-webkit-scrollbar{width:3px}.drawer-body[data-v-3835b845]::-webkit-scrollbar-thumb{background:var(--tb-border);border-radius:3px}.form-section[data-v-3835b845]{display:flex;flex-direction:column;gap:12px}.form-section-label[data-v-3835b845]{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.7px;padding-bottom:8px;border-bottom:1px solid var(--tb-border);transition:color .3s,border-color .3s}.form-section-label i[data-v-3835b845]{font-size:11px;color:var(--accent)}.form-group[data-v-3835b845]{display:flex;flex-direction:column;gap:5px}.form-label[data-v-3835b845]{font-size:11.5px;font-weight:700;color:var(--tb-text);transition:color .3s}.form-label.required[data-v-3835b845]:after{content:" *";color:#ef4444}.input-wrap[data-v-3835b845]{position:relative}.form-input[data-v-3835b845]{width:100%;padding:9px 36px 9px 12px;border:2px solid var(--tb-border);border-radius:8px;font-size:13px;font-family:inherit;font-weight:700;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s;box-sizing:border-box}.form-input[data-v-3835b845]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-input[data-v-3835b845]::placeholder{color:var(--tb-sub);font-weight:500;opacity:.8}.form-input-plain[data-v-3835b845]{padding-right:12px}.emp-autocomplete-wrap[data-v-3835b845]{position:relative}.emp-input[data-v-3835b845]{padding-right:36px}.emp-selected[data-v-3835b845]{border-color:#16a34a!important;background:#f0fdf4!important;color:#111827!important;font-weight:800!important}.emp-clear-btn[data-v-3835b845]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:13px;padding:4px;border-radius:4px;transition:color .2s,background .2s;display:flex;align-items:center}.emp-clear-btn[data-v-3835b845]:hover{color:#ef4444;background:#ef444414}.emp-dropdown[data-v-3835b845]{position:absolute;top:calc(100% + 4px);left:0;right:0;background:var(--tb-bg);border:2px solid var(--accent);border-radius:10px;box-shadow:0 8px 28px #00000029;z-index:999;max-height:230px;overflow-y:auto}.emp-dropdown[data-v-3835b845]::-webkit-scrollbar{width:3px}.emp-dropdown[data-v-3835b845]::-webkit-scrollbar-thumb{background:var(--tb-border);border-radius:3px}.emp-option[data-v-3835b845]{display:flex;align-items:center;padding:10px 14px;cursor:pointer;border-bottom:1.5px solid #d1d5db;transition:background .12s}.emp-option[data-v-3835b845]:last-child{border-bottom:none}.emp-option[data-v-3835b845]:hover{background:#f0f4ff}.emp-option-text[data-v-3835b845]{font-size:13px;font-weight:700;color:#111827;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.emp-loading[data-v-3835b845]{padding:14px}.dropdown-fade-enter-active[data-v-3835b845]{transition:opacity .15s,transform .15s}.dropdown-fade-leave-active[data-v-3835b845]{transition:opacity .1s,transform .1s}.dropdown-fade-enter-from[data-v-3835b845],.dropdown-fade-leave-to[data-v-3835b845]{opacity:0;transform:translateY(-4px)}.sig-upload-zone[data-v-3835b845]{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px 16px;border:2px dashed var(--tb-border);border-radius:10px;background:var(--sb-search-bg);cursor:pointer;transition:all .2s;min-height:100px}.sig-upload-zone[data-v-3835b845]:hover{border-color:var(--accent);background:var(--accent-glow2)}.sig-upload-zone.has-preview[data-v-3835b845]{padding:8px;border-style:solid;border-color:var(--accent);background:var(--accent-glow2)}.sig-upload-zone.is-uploading[data-v-3835b845]{cursor:not-allowed;opacity:.7}.sig-upload-icon[data-v-3835b845]{width:38px;height:38px;border-radius:10px;background:#1976d21a;display:flex;align-items:center;justify-content:center}.sig-upload-icon i[data-v-3835b845]{font-size:16px;color:var(--accent)}.sig-upload-text[data-v-3835b845]{font-size:12.5px;font-weight:700;color:var(--tb-text);transition:color .3s}.sig-upload-hint[data-v-3835b845]{font-size:11px;color:var(--tb-sub)}.sig-preview-img[data-v-3835b845]{max-height:80px;max-width:100%;object-fit:contain;border-radius:6px}.sig-remove-btn[data-v-3835b845]{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:#ef4444;color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:background .2s;box-shadow:0 2px 6px #ef444466}.sig-remove-btn[data-v-3835b845]:hover{background:#dc2626}.sig-error-box[data-v-3835b845]{display:flex;align-items:center;gap:7px;padding:8px 12px;margin-top:4px;background:#ef444412;border:1.5px solid rgba(239,68,68,.22);border-radius:8px;font-size:12px;font-weight:600;color:#dc2626}.sig-error-box i[data-v-3835b845]{font-size:13px;flex-shrink:0}.form-textarea[data-v-3835b845]{width:100%;padding:9px 12px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:500;background:var(--sb-search-bg);color:var(--tb-text);outline:none;resize:vertical;line-height:1.6;transition:all .2s}.form-textarea[data-v-3835b845]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-textarea[data-v-3835b845]::placeholder{color:var(--tb-sub);font-weight:400}.drawer-footer[data-v-3835b845]{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg);flex-shrink:0;transition:border-color .3s,background .3s}.btn-cancel[data-v-3835b845]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:none;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;color:var(--tb-sub);cursor:pointer;transition:all .2s}.btn-cancel[data-v-3835b845]:hover{border-color:#ef4444;color:#ef4444;background:#ef44440d}.btn-save[data-v-3835b845]{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px var(--accent-glow);transition:all .2s}.btn-save[data-v-3835b845]:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px)}.btn-save[data-v-3835b845]:disabled{opacity:.55;cursor:not-allowed;transform:none}.btn-spinner[data-v-3835b845]{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-3835b845 .6s linear infinite}.th-actions[data-v-3835b845]{text-align:center;width:90px}.td-actions[data-v-3835b845]{text-align:center}.actions-wrap[data-v-3835b845]{display:inline-flex;align-items:center;gap:6px}.btn-action[data-v-3835b845]{width:30px;height:30px;border-radius:7px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;transition:all .18s}.btn-edit[data-v-3835b845]{background:#1976d21a;color:var(--accent);border:1px solid rgba(25,118,210,.2)}.btn-edit[data-v-3835b845]:hover{background:var(--accent);color:#fff;transform:translateY(-1px);box-shadow:0 3px 10px var(--accent-glow)}.btn-delete[data-v-3835b845]{background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.18)}.btn-delete[data-v-3835b845]:hover{background:#ef4444;color:#fff;transform:translateY(-1px);box-shadow:0 3px 10px #ef44444d}.drawer-icon-edit[data-v-3835b845]{background:#f59e0b;box-shadow:0 3px 10px #f59e0b59}.modal-overlay[data-v-3835b845]{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box[data-v-3835b845]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:16px;box-shadow:0 20px 60px #0003;padding:28px 28px 24px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.modal-icon-wrap[data-v-3835b845]{width:52px;height:52px;border-radius:50%;background:#ef44441a;border:2px solid rgba(239,68,68,.2);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.modal-icon-wrap i[data-v-3835b845]{font-size:22px;color:#ef4444}.modal-title[data-v-3835b845]{font-size:16px;font-weight:800;color:var(--tb-text);margin:0}.modal-desc[data-v-3835b845]{font-size:13px;font-weight:500;color:var(--tb-sub);line-height:1.7;margin:0}.modal-desc strong[data-v-3835b845]{color:var(--tb-text);font-weight:800}.modal-warn[data-v-3835b845]{font-size:11.5px;color:#ef4444;font-weight:600}.modal-actions[data-v-3835b845]{display:flex;gap:10px;margin-top:4px;width:100%;justify-content:center}.btn-delete-confirm[data-v-3835b845]{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;background:#ef4444;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px #ef44444d;transition:all .2s}.btn-delete-confirm[data-v-3835b845]:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-delete-confirm[data-v-3835b845]:disabled{opacity:.55;cursor:not-allowed}.delete-error-box[data-v-3835b845]{display:flex;align-items:flex-start;gap:8px;width:100%;padding:10px 14px;background:#ef444412;border:1.5px solid rgba(239,68,68,.25);border-radius:9px;font-size:12.5px;font-weight:600;color:#dc2626;text-align:left;line-height:1.5}.delete-error-box i[data-v-3835b845]{font-size:14px;flex-shrink:0;margin-top:1px}.modal-pop-enter-active[data-v-3835b845]{transition:opacity .2s,transform .2s}.modal-pop-leave-active[data-v-3835b845]{transition:opacity .15s,transform .15s}.modal-pop-enter-from[data-v-3835b845],.modal-pop-leave-to[data-v-3835b845]{opacity:0;transform:scale(.92)}.overlay-fade-enter-active[data-v-3835b845],.overlay-fade-leave-active[data-v-3835b845]{transition:opacity .25s ease}.overlay-fade-enter-from[data-v-3835b845],.overlay-fade-leave-to[data-v-3835b845]{opacity:0}.drawer-slide-enter-active[data-v-3835b845]{transition:transform .3s cubic-bezier(.32,.72,0,1)}.drawer-slide-leave-active[data-v-3835b845]{transition:transform .25s cubic-bezier(.32,.72,0,1)}.drawer-slide-enter-from[data-v-3835b845],.drawer-slide-leave-to[data-v-3835b845]{transform:translate(100%)}.fade-enter-active[data-v-3835b845],.fade-leave-active[data-v-3835b845]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-3835b845],.fade-leave-to[data-v-3835b845]{opacity:0;transform:scale(.95)}@media(max-width:480px){.drawer-panel[data-v-3835b845]{width:100%}}@font-face{font-family:"Noto Serif Lao";src:url(data:font/ttf;base64,QGZvbnQtZmFjZSB7CiAgZm9udC1mYW1pbHk6ICdOb3RvIFNlcmlmIExhbyc7CiAgc3JjOiB1cmwoJ0AvZm9udHMvTm90b1NlcmlmTGFvLS50dGYnKSBmb3JtYXQoJ3RydWV0eXBlJyk7CiAgZm9udC13ZWlnaHQ6IDQwMDsKICBmb250LXN0eWxlOiBub3JtYWw7Cn0=) format("truetype");font-weight:400}@font-face{font-family:"Noto Serif Lao";src:url(data:font/ttf;base64,QGZvbnQtZmFjZSB7CiAgZm9udC1mYW1pbHk6ICdOb3RvIFNlcmlmIExhbyc7CiAgc3JjOiB1cmwoJ0AvZm9udHMvTm90b1NlcmlmTGFvLS50dGYnKSBmb3JtYXQoJ3RydWV0eXBlJyk7CiAgZm9udC13ZWlnaHQ6IDQwMDsKICBmb250LXN0eWxlOiBub3JtYWw7Cn0=) format("truetype");font-weight:700}.page-wrapper[data-v-d16f5c92]{padding:0;font-family:"Noto Serif Lao",Nunito,Barlow,sans-serif;position:relative}.page-header[data-v-d16f5c92]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left[data-v-d16f5c92]{display:flex;align-items:center;gap:14px}.page-icon-wrap[data-v-d16f5c92]{width:44px;height:44px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--accent-glow);flex-shrink:0}.page-icon-wrap i[data-v-d16f5c92]{color:#fff;font-size:18px}.page-title[data-v-d16f5c92]{font-size:18px;font-weight:800;color:var(--tb-text);line-height:1.2;margin:0;transition:color .3s}.page-subtitle[data-v-d16f5c92]{font-size:12px;color:var(--tb-sub);margin:2px 0 0;transition:color .3s}.btn-add[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 14px var(--accent-glow);transition:all .2s}.btn-add[data-v-d16f5c92]:hover{background:var(--accent-dark);transform:translateY(-1px)}.btn-add i[data-v-d16f5c92]{font-size:12px}.card[data-v-d16f5c92]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;transition:background .3s,border-color .3s}.card-toolbar[data-v-d16f5c92]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--tb-border);flex-wrap:wrap;transition:border-color .3s}.toolbar-left[data-v-d16f5c92]{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.toolbar-right[data-v-d16f5c92]{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box[data-v-d16f5c92]{position:relative;min-width:200px;max-width:340px;flex:1}.search-icon[data-v-d16f5c92]{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tb-sub);font-size:13px;pointer-events:none}.search-input[data-v-d16f5c92]{width:100%;padding:8px 32px 8px 34px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s}.search-input[data-v-d16f5c92]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.search-input[data-v-d16f5c92]::placeholder{color:var(--tb-sub);font-weight:500}.search-clear[data-v-d16f5c92]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:12px;padding:3px;border-radius:4px;transition:color .2s}.search-clear[data-v-d16f5c92]:hover{color:#ef4444}.result-chip[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:20px;font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap}.count-chip[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--sb-search-bg);border:1px solid var(--tb-border);border-radius:20px;font-size:12px;font-weight:600;color:var(--tb-sub);white-space:nowrap}.table-wrapper[data-v-d16f5c92]{overflow-x:auto}.doc-table[data-v-d16f5c92]{width:100%;border-collapse:collapse;font-size:12.5px;min-width:600px}.doc-table thead tr[data-v-d16f5c92]{background:var(--sb-search-bg);border-bottom:2px solid var(--tb-border)}.doc-table th[data-v-d16f5c92]{padding:11px 14px;text-align:left;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}.th-num[data-v-d16f5c92]{width:44px;text-align:center}.doc-table tbody tr[data-v-d16f5c92]{border-bottom:1px solid var(--tb-border);transition:background .15s}.doc-table tbody tr[data-v-d16f5c92]:last-child{border-bottom:none}.data-row[data-v-d16f5c92]:hover{background:var(--sb-hover)}.doc-table td[data-v-d16f5c92]{padding:11px 14px;color:var(--tb-text);vertical-align:middle}.td-num[data-v-d16f5c92]{text-align:center;font-size:11.5px;font-weight:700;color:var(--tb-sub)}.cell-name[data-v-d16f5c92]{display:flex;align-items:center;gap:9px}.avatar-circle[data-v-d16f5c92]{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px var(--accent-glow)}.name-text[data-v-d16f5c92]{font-weight:700;color:var(--tb-text)}.cell-detail[data-v-d16f5c92]{max-width:300px}.detail-text[data-v-d16f5c92]{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:12px;color:var(--tb-sub);font-weight:500;line-height:1.5}.creator-tag[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--tb-sub)}.date-cell[data-v-d16f5c92]{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--tb-sub);font-weight:600;white-space:nowrap}.date-icon[data-v-d16f5c92]{font-size:11px;opacity:.5}.null-dash[data-v-d16f5c92]{color:var(--tb-border);font-size:14px}.state-cell[data-v-d16f5c92]{padding:0!important}.state-content[data-v-d16f5c92]{display:flex;flex-direction:column;align-items:center;gap:10px;padding:52px 24px;color:var(--tb-sub);font-size:13px;font-weight:600}.empty-icon-wrap[data-v-d16f5c92]{width:52px;height:52px;border-radius:50%;background:var(--sb-search-bg);border:2px dashed var(--tb-border);display:flex;align-items:center;justify-content:center}.empty-icon-wrap i[data-v-d16f5c92]{font-size:20px;color:var(--tb-sub);opacity:.5}.empty-title[data-v-d16f5c92]{font-size:13.5px;font-weight:700;color:var(--tb-text)}.empty-sub[data-v-d16f5c92]{font-size:12px;color:var(--tb-sub)}.btn-add-empty[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;margin-top:4px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;transition:background .2s}.btn-add-empty[data-v-d16f5c92]:hover{background:var(--accent-dark)}.spinner[data-v-d16f5c92]{width:28px;height:28px;border:3px solid var(--tb-border);border-top-color:var(--accent);border-radius:50%;animation:spin-d16f5c92 .7s linear infinite}@keyframes spin-d16f5c92{to{transform:rotate(360deg)}}.card-footer[data-v-d16f5c92]{padding:10px 16px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg)}.th-actions[data-v-d16f5c92]{text-align:center;width:90px}.td-actions[data-v-d16f5c92]{text-align:center}.actions-wrap[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:6px}.btn-action[data-v-d16f5c92]{width:30px;height:30px;border-radius:7px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;transition:all .18s}.btn-edit[data-v-d16f5c92]{background:#1976d21a;color:var(--accent);border:1px solid rgba(25,118,210,.2)}.btn-edit[data-v-d16f5c92]:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.btn-delete[data-v-d16f5c92]{background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.18)}.btn-delete[data-v-d16f5c92]:hover{background:#ef4444;color:#fff;transform:translateY(-1px)}.drawer-overlay[data-v-d16f5c92]{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400}.drawer-panel[data-v-d16f5c92]{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--tb-bg);border-left:1px solid var(--tb-border);box-shadow:-8px 0 40px #00000024;z-index:500;display:flex;flex-direction:column;overflow:hidden}.drawer-header[data-v-d16f5c92]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--tb-border);flex-shrink:0}.drawer-header-left[data-v-d16f5c92]{display:flex;align-items:center;gap:12px}.drawer-icon[data-v-d16f5c92]{width:38px;height:38px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px var(--accent-glow);flex-shrink:0}.drawer-icon i[data-v-d16f5c92]{color:#fff;font-size:15px}.drawer-icon-edit[data-v-d16f5c92]{background:#f59e0b;box-shadow:0 3px 10px #f59e0b59}.drawer-title[data-v-d16f5c92]{font-size:15px;font-weight:800;color:var(--tb-text);margin:0}.drawer-sub[data-v-d16f5c92]{font-size:11.5px;color:var(--tb-sub);margin:1px 0 0}.drawer-close[data-v-d16f5c92]{width:32px;height:32px;border-radius:8px;background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .2s}.drawer-close[data-v-d16f5c92]:hover{background:#ef44441a;color:#ef4444}.drawer-body[data-v-d16f5c92]{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.drawer-body[data-v-d16f5c92]::-webkit-scrollbar{width:3px}.drawer-body[data-v-d16f5c92]::-webkit-scrollbar-thumb{background:var(--tb-border);border-radius:3px}.form-section[data-v-d16f5c92]{display:flex;flex-direction:column;gap:12px}.form-section-label[data-v-d16f5c92]{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.7px;padding-bottom:8px;border-bottom:1px solid var(--tb-border)}.form-section-label i[data-v-d16f5c92]{font-size:11px;color:var(--accent)}.form-group[data-v-d16f5c92]{display:flex;flex-direction:column;gap:5px}.form-label[data-v-d16f5c92]{font-size:11.5px;font-weight:700;color:var(--tb-text)}.form-label.required[data-v-d16f5c92]:after{content:" *";color:#ef4444}.form-input[data-v-d16f5c92]{width:100%;padding:9px 12px;border:2px solid var(--tb-border);border-radius:8px;font-size:13px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s;box-sizing:border-box}.form-input[data-v-d16f5c92]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-input[data-v-d16f5c92]::placeholder{color:var(--tb-sub);font-weight:500;opacity:.8}.form-textarea[data-v-d16f5c92]{width:100%;padding:9px 12px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:500;background:var(--sb-search-bg);color:var(--tb-text);outline:none;resize:vertical;line-height:1.6;transition:all .2s}.form-textarea[data-v-d16f5c92]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-textarea[data-v-d16f5c92]::placeholder{color:var(--tb-sub);font-weight:400}.drawer-footer[data-v-d16f5c92]{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg);flex-shrink:0}.btn-cancel[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:none;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;color:var(--tb-sub);cursor:pointer;transition:all .2s}.btn-cancel[data-v-d16f5c92]:hover{border-color:#ef4444;color:#ef4444}.btn-save[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px var(--accent-glow);transition:all .2s}.btn-save[data-v-d16f5c92]:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px)}.btn-save[data-v-d16f5c92]:disabled{opacity:.55;cursor:not-allowed}.btn-spinner[data-v-d16f5c92]{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-d16f5c92 .6s linear infinite}.modal-overlay[data-v-d16f5c92]{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box[data-v-d16f5c92]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:16px;box-shadow:0 20px 60px #0003;padding:28px 28px 24px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.modal-icon-wrap[data-v-d16f5c92]{width:52px;height:52px;border-radius:50%;background:#ef44441a;border:2px solid rgba(239,68,68,.2);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.modal-icon-wrap i[data-v-d16f5c92]{font-size:22px;color:#ef4444}.modal-title[data-v-d16f5c92]{font-size:16px;font-weight:800;color:var(--tb-text);margin:0}.modal-desc[data-v-d16f5c92]{font-size:13px;font-weight:500;color:var(--tb-sub);line-height:1.7;margin:0}.modal-desc strong[data-v-d16f5c92]{color:var(--tb-text);font-weight:800}.modal-warn[data-v-d16f5c92]{font-size:11.5px;color:#ef4444;font-weight:600}.modal-actions[data-v-d16f5c92]{display:flex;gap:10px;margin-top:4px;width:100%;justify-content:center}.btn-delete-confirm[data-v-d16f5c92]{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;background:#ef4444;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px #ef44444d;transition:all .2s}.btn-delete-confirm[data-v-d16f5c92]:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-delete-confirm[data-v-d16f5c92]:disabled{opacity:.55;cursor:not-allowed}.delete-error-box[data-v-d16f5c92]{display:flex;align-items:flex-start;gap:8px;width:100%;padding:10px 14px;background:#ef444412;border:1.5px solid rgba(239,68,68,.25);border-radius:9px;font-size:12.5px;font-weight:600;color:#dc2626;text-align:left;line-height:1.5}.delete-error-box i[data-v-d16f5c92]{font-size:14px;flex-shrink:0;margin-top:1px}.modal-pop-enter-active[data-v-d16f5c92]{transition:opacity .2s,transform .2s}.modal-pop-leave-active[data-v-d16f5c92]{transition:opacity .15s,transform .15s}.modal-pop-enter-from[data-v-d16f5c92],.modal-pop-leave-to[data-v-d16f5c92]{opacity:0;transform:scale(.92)}.overlay-fade-enter-active[data-v-d16f5c92],.overlay-fade-leave-active[data-v-d16f5c92]{transition:opacity .25s ease}.overlay-fade-enter-from[data-v-d16f5c92],.overlay-fade-leave-to[data-v-d16f5c92]{opacity:0}.drawer-slide-enter-active[data-v-d16f5c92]{transition:transform .3s cubic-bezier(.32,.72,0,1)}.drawer-slide-leave-active[data-v-d16f5c92]{transition:transform .25s cubic-bezier(.32,.72,0,1)}.drawer-slide-enter-from[data-v-d16f5c92],.drawer-slide-leave-to[data-v-d16f5c92]{transform:translate(100%)}.fade-enter-active[data-v-d16f5c92],.fade-leave-active[data-v-d16f5c92]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-d16f5c92],.fade-leave-to[data-v-d16f5c92]{opacity:0;transform:scale(.95)}@media(max-width:480px){.drawer-panel[data-v-d16f5c92]{width:100%}}.page-wrapper[data-v-7ea1c755]{padding:0;font-family:Nunito,Barlow,sans-serif;position:relative}.page-header[data-v-7ea1c755]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left[data-v-7ea1c755]{display:flex;align-items:center;gap:14px}.page-icon-wrap[data-v-7ea1c755]{width:44px;height:44px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--accent-glow);flex-shrink:0}.page-icon-wrap i[data-v-7ea1c755]{color:#fff;font-size:18px}.page-title[data-v-7ea1c755]{font-size:18px;font-weight:800;color:var(--tb-text);line-height:1.2;margin:0;transition:color .3s}.page-subtitle[data-v-7ea1c755]{font-size:12px;color:var(--tb-sub);margin:2px 0 0;transition:color .3s}.btn-add[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 14px var(--accent-glow);transition:all .2s}.btn-add[data-v-7ea1c755]:hover{background:var(--accent-dark);transform:translateY(-1px)}.btn-add i[data-v-7ea1c755]{font-size:12px}.card[data-v-7ea1c755]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;transition:background .3s,border-color .3s}.card-toolbar[data-v-7ea1c755]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--tb-border);flex-wrap:wrap;transition:border-color .3s}.toolbar-left[data-v-7ea1c755]{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.toolbar-right[data-v-7ea1c755]{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box[data-v-7ea1c755]{position:relative;min-width:200px;max-width:340px;flex:1}.search-icon[data-v-7ea1c755]{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tb-sub);font-size:13px;pointer-events:none}.search-input[data-v-7ea1c755]{width:100%;padding:8px 32px 8px 34px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s}.search-input[data-v-7ea1c755]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.search-input[data-v-7ea1c755]::placeholder{color:var(--tb-sub);font-weight:500}.search-clear[data-v-7ea1c755]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:12px;padding:3px;border-radius:4px;transition:color .2s}.search-clear[data-v-7ea1c755]:hover{color:#ef4444}.result-chip[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:20px;font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap}.count-chip[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--sb-search-bg);border:1px solid var(--tb-border);border-radius:20px;font-size:12px;font-weight:600;color:var(--tb-sub);white-space:nowrap}.table-wrapper[data-v-7ea1c755]{overflow-x:auto}.incident-table[data-v-7ea1c755]{width:100%;border-collapse:collapse;font-size:12.5px;min-width:700px}.incident-table thead tr[data-v-7ea1c755]{background:var(--sb-search-bg);border-bottom:2px solid var(--tb-border)}.incident-table th[data-v-7ea1c755]{padding:11px 14px;text-align:left;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}.th-num[data-v-7ea1c755]{width:44px;text-align:center}.incident-table tbody tr[data-v-7ea1c755]{border-bottom:1px solid var(--tb-border);transition:background .15s}.incident-table tbody tr[data-v-7ea1c755]:last-child{border-bottom:none}.data-row[data-v-7ea1c755]:hover{background:var(--sb-hover)}.incident-table td[data-v-7ea1c755]{padding:11px 14px;color:var(--tb-text);vertical-align:middle}.td-num[data-v-7ea1c755]{text-align:center;font-size:11.5px;font-weight:700;color:var(--tb-sub)}.badge-doctype[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:6px;font-size:11.5px;font-weight:700;color:var(--accent);white-space:nowrap}.badge-doctype i[data-v-7ea1c755]{font-size:10px;opacity:.7}.cell-name[data-v-7ea1c755]{display:flex;align-items:center;gap:9px}.avatar-circle[data-v-7ea1c755]{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px var(--accent-glow)}.name-text[data-v-7ea1c755]{font-weight:700;color:var(--tb-text)}.cell-detail[data-v-7ea1c755]{max-width:260px}.detail-text[data-v-7ea1c755]{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:12px;color:var(--tb-sub);font-weight:500;line-height:1.5}.creator-tag[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--tb-sub)}.date-cell[data-v-7ea1c755]{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--tb-sub);font-weight:600;white-space:nowrap}.date-icon[data-v-7ea1c755]{font-size:11px;opacity:.5}.null-dash[data-v-7ea1c755]{color:var(--tb-border);font-size:14px}.state-cell[data-v-7ea1c755]{padding:0!important}.state-content[data-v-7ea1c755]{display:flex;flex-direction:column;align-items:center;gap:10px;padding:52px 24px;color:var(--tb-sub);font-size:13px;font-weight:600}.empty-icon-wrap[data-v-7ea1c755]{width:52px;height:52px;border-radius:50%;background:var(--sb-search-bg);border:2px dashed var(--tb-border);display:flex;align-items:center;justify-content:center}.empty-icon-wrap i[data-v-7ea1c755]{font-size:20px;color:var(--tb-sub);opacity:.5}.empty-title[data-v-7ea1c755]{font-size:13.5px;font-weight:700;color:var(--tb-text)}.empty-sub[data-v-7ea1c755]{font-size:12px;color:var(--tb-sub)}.btn-add-empty[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;margin-top:4px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;transition:background .2s}.btn-add-empty[data-v-7ea1c755]:hover{background:var(--accent-dark)}.spinner[data-v-7ea1c755]{width:28px;height:28px;border:3px solid var(--tb-border);border-top-color:var(--accent);border-radius:50%;animation:spin-7ea1c755 .7s linear infinite}@keyframes spin-7ea1c755{to{transform:rotate(360deg)}}.card-footer[data-v-7ea1c755]{padding:10px 16px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg)}.th-actions[data-v-7ea1c755]{text-align:center;width:90px}.td-actions[data-v-7ea1c755]{text-align:center}.actions-wrap[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:6px}.btn-action[data-v-7ea1c755]{width:30px;height:30px;border-radius:7px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;transition:all .18s}.btn-edit[data-v-7ea1c755]{background:#1976d21a;color:var(--accent);border:1px solid rgba(25,118,210,.2)}.btn-edit[data-v-7ea1c755]:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.btn-delete[data-v-7ea1c755]{background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.18)}.btn-delete[data-v-7ea1c755]:hover{background:#ef4444;color:#fff;transform:translateY(-1px)}.select-wrap[data-v-7ea1c755]{position:relative}.form-select[data-v-7ea1c755]{width:100%;padding:9px 36px 9px 12px;border:2px solid var(--tb-border);border-radius:8px;font-size:13px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;appearance:none;cursor:pointer;transition:all .2s;box-sizing:border-box}.form-select[data-v-7ea1c755]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.select-icon[data-v-7ea1c755]{position:absolute;right:12px;top:50%;transform:translateY(-50%);font-size:11px;color:var(--tb-sub);pointer-events:none}.drawer-overlay[data-v-7ea1c755]{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400}.drawer-panel[data-v-7ea1c755]{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--tb-bg);border-left:1px solid var(--tb-border);box-shadow:-8px 0 40px #00000024;z-index:500;display:flex;flex-direction:column;overflow:hidden}.drawer-header[data-v-7ea1c755]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--tb-border);flex-shrink:0}.drawer-header-left[data-v-7ea1c755]{display:flex;align-items:center;gap:12px}.drawer-icon[data-v-7ea1c755]{width:38px;height:38px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px var(--accent-glow);flex-shrink:0}.drawer-icon i[data-v-7ea1c755]{color:#fff;font-size:15px}.drawer-icon-edit[data-v-7ea1c755]{background:#f59e0b;box-shadow:0 3px 10px #f59e0b59}.drawer-title[data-v-7ea1c755]{font-size:15px;font-weight:800;color:var(--tb-text);margin:0}.drawer-sub[data-v-7ea1c755]{font-size:11.5px;color:var(--tb-sub);margin:1px 0 0}.drawer-close[data-v-7ea1c755]{width:32px;height:32px;border-radius:8px;background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .2s}.drawer-close[data-v-7ea1c755]:hover{background:#ef44441a;color:#ef4444}.drawer-body[data-v-7ea1c755]{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.drawer-body[data-v-7ea1c755]::-webkit-scrollbar{width:3px}.drawer-body[data-v-7ea1c755]::-webkit-scrollbar-thumb{background:var(--tb-border);border-radius:3px}.form-section[data-v-7ea1c755]{display:flex;flex-direction:column;gap:12px}.form-section-label[data-v-7ea1c755]{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.7px;padding-bottom:8px;border-bottom:1px solid var(--tb-border)}.form-section-label i[data-v-7ea1c755]{font-size:11px;color:var(--accent)}.form-group[data-v-7ea1c755]{display:flex;flex-direction:column;gap:5px}.form-label[data-v-7ea1c755]{font-size:11.5px;font-weight:700;color:var(--tb-text)}.form-label.required[data-v-7ea1c755]:after{content:" *";color:#ef4444}.form-input[data-v-7ea1c755]{width:100%;padding:9px 12px;border:2px solid var(--tb-border);border-radius:8px;font-size:13px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s;box-sizing:border-box}.form-input[data-v-7ea1c755]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-input[data-v-7ea1c755]::placeholder{color:var(--tb-sub);font-weight:500;opacity:.8}.form-textarea[data-v-7ea1c755]{width:100%;padding:9px 12px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:500;background:var(--sb-search-bg);color:var(--tb-text);outline:none;resize:vertical;line-height:1.6;transition:all .2s}.form-textarea[data-v-7ea1c755]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-textarea[data-v-7ea1c755]::placeholder{color:var(--tb-sub);font-weight:400}.drawer-footer[data-v-7ea1c755]{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg);flex-shrink:0}.btn-cancel[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:none;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;color:var(--tb-sub);cursor:pointer;transition:all .2s}.btn-cancel[data-v-7ea1c755]:hover{border-color:#ef4444;color:#ef4444}.btn-save[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px var(--accent-glow);transition:all .2s}.btn-save[data-v-7ea1c755]:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px)}.btn-save[data-v-7ea1c755]:disabled{opacity:.55;cursor:not-allowed}.btn-spinner[data-v-7ea1c755]{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-7ea1c755 .6s linear infinite}.modal-overlay[data-v-7ea1c755]{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box[data-v-7ea1c755]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:16px;box-shadow:0 20px 60px #0003;padding:28px 28px 24px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.modal-icon-wrap[data-v-7ea1c755]{width:52px;height:52px;border-radius:50%;background:#ef44441a;border:2px solid rgba(239,68,68,.2);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.modal-icon-wrap i[data-v-7ea1c755]{font-size:22px;color:#ef4444}.modal-title[data-v-7ea1c755]{font-size:16px;font-weight:800;color:var(--tb-text);margin:0}.modal-desc[data-v-7ea1c755]{font-size:13px;font-weight:500;color:var(--tb-sub);line-height:1.7;margin:0}.modal-desc strong[data-v-7ea1c755]{color:var(--tb-text);font-weight:800}.modal-warn[data-v-7ea1c755]{font-size:11.5px;color:#ef4444;font-weight:600}.modal-actions[data-v-7ea1c755]{display:flex;gap:10px;margin-top:4px;width:100%;justify-content:center}.btn-delete-confirm[data-v-7ea1c755]{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;background:#ef4444;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px #ef44444d;transition:all .2s}.btn-delete-confirm[data-v-7ea1c755]:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-delete-confirm[data-v-7ea1c755]:disabled{opacity:.55;cursor:not-allowed}.delete-error-box[data-v-7ea1c755]{display:flex;align-items:flex-start;gap:8px;width:100%;padding:10px 14px;background:#ef444412;border:1.5px solid rgba(239,68,68,.25);border-radius:9px;font-size:12.5px;font-weight:600;color:#dc2626;text-align:left;line-height:1.5}.delete-error-box i[data-v-7ea1c755]{font-size:14px;flex-shrink:0;margin-top:1px}.modal-pop-enter-active[data-v-7ea1c755]{transition:opacity .2s,transform .2s}.modal-pop-leave-active[data-v-7ea1c755]{transition:opacity .15s,transform .15s}.modal-pop-enter-from[data-v-7ea1c755],.modal-pop-leave-to[data-v-7ea1c755]{opacity:0;transform:scale(.92)}.overlay-fade-enter-active[data-v-7ea1c755],.overlay-fade-leave-active[data-v-7ea1c755]{transition:opacity .25s ease}.overlay-fade-enter-from[data-v-7ea1c755],.overlay-fade-leave-to[data-v-7ea1c755]{opacity:0}.drawer-slide-enter-active[data-v-7ea1c755]{transition:transform .3s cubic-bezier(.32,.72,0,1)}.drawer-slide-leave-active[data-v-7ea1c755]{transition:transform .25s cubic-bezier(.32,.72,0,1)}.drawer-slide-enter-from[data-v-7ea1c755],.drawer-slide-leave-to[data-v-7ea1c755]{transform:translate(100%)}.fade-enter-active[data-v-7ea1c755],.fade-leave-active[data-v-7ea1c755]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-7ea1c755],.fade-leave-to[data-v-7ea1c755]{opacity:0;transform:scale(.95)}@media(max-width:480px){.drawer-panel[data-v-7ea1c755]{width:100%}}.page-wrapper[data-v-cb375af1]{padding:0;font-family:Nunito,Barlow,sans-serif;position:relative}.page-header[data-v-cb375af1]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left[data-v-cb375af1]{display:flex;align-items:center;gap:14px}.page-icon-wrap[data-v-cb375af1]{width:44px;height:44px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--accent-glow);flex-shrink:0}.page-icon-wrap i[data-v-cb375af1]{color:#fff;font-size:18px}.page-title[data-v-cb375af1]{font-size:18px;font-weight:800;color:var(--tb-text);line-height:1.2;margin:0;transition:color .3s}.page-subtitle[data-v-cb375af1]{font-size:12px;color:var(--tb-sub);margin:2px 0 0;transition:color .3s}.btn-add[data-v-cb375af1]{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 14px var(--accent-glow);transition:all .2s}.btn-add[data-v-cb375af1]:hover{background:var(--accent-dark);transform:translateY(-1px)}.btn-add i[data-v-cb375af1]{font-size:12px}.card[data-v-cb375af1]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;transition:background .3s,border-color .3s}.card-toolbar[data-v-cb375af1]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--tb-border);flex-wrap:wrap;transition:border-color .3s}.toolbar-left[data-v-cb375af1]{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.toolbar-right[data-v-cb375af1]{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box[data-v-cb375af1]{position:relative;min-width:200px;max-width:340px;flex:1}.search-icon[data-v-cb375af1]{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tb-sub);font-size:13px;pointer-events:none}.search-input[data-v-cb375af1]{width:100%;padding:8px 32px 8px 34px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s}.search-input[data-v-cb375af1]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.search-input[data-v-cb375af1]::placeholder{color:var(--tb-sub);font-weight:500}.search-clear[data-v-cb375af1]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:12px;padding:3px;border-radius:4px;transition:color .2s}.search-clear[data-v-cb375af1]:hover{color:#ef4444}.result-chip[data-v-cb375af1]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:20px;font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap}.count-chip[data-v-cb375af1]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--sb-search-bg);border:1px solid var(--tb-border);border-radius:20px;font-size:12px;font-weight:600;color:var(--tb-sub);white-space:nowrap}.table-wrapper[data-v-cb375af1]{overflow-x:auto}.penalty-table[data-v-cb375af1]{width:100%;border-collapse:collapse;font-size:12.5px;min-width:700px}.penalty-table thead tr[data-v-cb375af1]{background:var(--sb-search-bg);border-bottom:2px solid var(--tb-border)}.penalty-table th[data-v-cb375af1]{padding:11px 14px;text-align:left;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}.th-num[data-v-cb375af1]{width:44px;text-align:center}.penalty-table tbody tr[data-v-cb375af1]{border-bottom:1px solid var(--tb-border);transition:background .15s}.penalty-table tbody tr[data-v-cb375af1]:last-child{border-bottom:none}.data-row[data-v-cb375af1]:hover{background:var(--sb-hover)}.penalty-table td[data-v-cb375af1]{padding:11px 14px;color:var(--tb-text);vertical-align:middle}.td-num[data-v-cb375af1]{text-align:center;font-size:11.5px;font-weight:700;color:var(--tb-sub)}.cell-name[data-v-cb375af1]{display:flex;align-items:center;gap:9px}.avatar-circle[data-v-cb375af1]{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px var(--accent-glow)}.name-text[data-v-cb375af1]{font-weight:700;color:var(--tb-text)}.cell-detail[data-v-cb375af1]{max-width:260px}.detail-text[data-v-cb375af1]{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:12px;color:var(--tb-sub);font-weight:500;line-height:1.5}.badge-type[data-v-cb375af1]{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#7c3aed14;border:1px solid rgba(124,58,237,.15);border-radius:6px;font-size:11.5px;font-weight:700;color:#7c3aed;white-space:nowrap}.badge-type i[data-v-cb375af1]{font-size:10px;opacity:.7}.creator-tag[data-v-cb375af1]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--tb-sub)}.date-cell[data-v-cb375af1]{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--tb-sub);font-weight:600;white-space:nowrap}.date-icon[data-v-cb375af1]{font-size:11px;opacity:.5}.null-dash[data-v-cb375af1]{color:var(--tb-border);font-size:14px}.state-cell[data-v-cb375af1]{padding:0!important}.state-content[data-v-cb375af1]{display:flex;flex-direction:column;align-items:center;gap:10px;padding:52px 24px;color:var(--tb-sub);font-size:13px;font-weight:600}.empty-icon-wrap[data-v-cb375af1]{width:52px;height:52px;border-radius:50%;background:var(--sb-search-bg);border:2px dashed var(--tb-border);display:flex;align-items:center;justify-content:center}.empty-icon-wrap i[data-v-cb375af1]{font-size:20px;color:var(--tb-sub);opacity:.5}.empty-title[data-v-cb375af1]{font-size:13.5px;font-weight:700;color:var(--tb-text)}.empty-sub[data-v-cb375af1]{font-size:12px;color:var(--tb-sub)}.btn-add-empty[data-v-cb375af1]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;margin-top:4px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;transition:background .2s}.btn-add-empty[data-v-cb375af1]:hover{background:var(--accent-dark)}.spinner[data-v-cb375af1]{width:28px;height:28px;border:3px solid var(--tb-border);border-top-color:var(--accent);border-radius:50%;animation:spin-cb375af1 .7s linear infinite}@keyframes spin-cb375af1{to{transform:rotate(360deg)}}.card-footer[data-v-cb375af1]{padding:10px 16px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg)}.th-actions[data-v-cb375af1]{text-align:center;width:90px}.td-actions[data-v-cb375af1]{text-align:center}.actions-wrap[data-v-cb375af1]{display:inline-flex;align-items:center;gap:6px}.btn-action[data-v-cb375af1]{width:30px;height:30px;border-radius:7px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;transition:all .18s}.btn-edit[data-v-cb375af1]{background:#1976d21a;color:var(--accent);border:1px solid rgba(25,118,210,.2)}.btn-edit[data-v-cb375af1]:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.btn-delete[data-v-cb375af1]{background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.18)}.btn-delete[data-v-cb375af1]:hover{background:#ef4444;color:#fff;transform:translateY(-1px)}.drawer-overlay[data-v-cb375af1]{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400}.drawer-panel[data-v-cb375af1]{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--tb-bg);border-left:1px solid var(--tb-border);box-shadow:-8px 0 40px #00000024;z-index:500;display:flex;flex-direction:column;overflow:hidden}.drawer-header[data-v-cb375af1]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--tb-border);flex-shrink:0}.drawer-header-left[data-v-cb375af1]{display:flex;align-items:center;gap:12px}.drawer-icon[data-v-cb375af1]{width:38px;height:38px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px var(--accent-glow);flex-shrink:0}.drawer-icon i[data-v-cb375af1]{color:#fff;font-size:15px}.drawer-icon-edit[data-v-cb375af1]{background:#f59e0b;box-shadow:0 3px 10px #f59e0b59}.drawer-title[data-v-cb375af1]{font-size:15px;font-weight:800;color:var(--tb-text);margin:0}.drawer-sub[data-v-cb375af1]{font-size:11.5px;color:var(--tb-sub);margin:1px 0 0}.drawer-close[data-v-cb375af1]{width:32px;height:32px;border-radius:8px;background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .2s}.drawer-close[data-v-cb375af1]:hover{background:#ef44441a;color:#ef4444}.drawer-body[data-v-cb375af1]{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.drawer-body[data-v-cb375af1]::-webkit-scrollbar{width:3px}.drawer-body[data-v-cb375af1]::-webkit-scrollbar-thumb{background:var(--tb-border);border-radius:3px}.form-section[data-v-cb375af1]{display:flex;flex-direction:column;gap:12px}.form-section-label[data-v-cb375af1]{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.7px;padding-bottom:8px;border-bottom:1px solid var(--tb-border)}.form-section-label i[data-v-cb375af1]{font-size:11px;color:var(--accent)}.form-group[data-v-cb375af1]{display:flex;flex-direction:column;gap:5px}.form-label[data-v-cb375af1]{font-size:11.5px;font-weight:700;color:var(--tb-text)}.form-label.required[data-v-cb375af1]:after{content:" *";color:#ef4444}.form-input[data-v-cb375af1]{width:100%;padding:9px 12px;border:2px solid var(--tb-border);border-radius:8px;font-size:13px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s;box-sizing:border-box}.form-input[data-v-cb375af1]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-input[data-v-cb375af1]::placeholder{color:var(--tb-sub);font-weight:500;opacity:.8}.form-textarea[data-v-cb375af1]{width:100%;padding:9px 12px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:500;background:var(--sb-search-bg);color:var(--tb-text);outline:none;resize:vertical;line-height:1.6;transition:all .2s}.form-textarea[data-v-cb375af1]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-textarea[data-v-cb375af1]::placeholder{color:var(--tb-sub);font-weight:400}.drawer-footer[data-v-cb375af1]{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg);flex-shrink:0}.btn-cancel[data-v-cb375af1]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:none;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;color:var(--tb-sub);cursor:pointer;transition:all .2s}.btn-cancel[data-v-cb375af1]:hover{border-color:#ef4444;color:#ef4444}.btn-save[data-v-cb375af1]{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px var(--accent-glow);transition:all .2s}.btn-save[data-v-cb375af1]:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px)}.btn-save[data-v-cb375af1]:disabled{opacity:.55;cursor:not-allowed}.btn-spinner[data-v-cb375af1]{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-cb375af1 .6s linear infinite}.modal-overlay[data-v-cb375af1]{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box[data-v-cb375af1]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:16px;box-shadow:0 20px 60px #0003;padding:28px 28px 24px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.modal-icon-wrap[data-v-cb375af1]{width:52px;height:52px;border-radius:50%;background:#ef44441a;border:2px solid rgba(239,68,68,.2);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.modal-icon-wrap i[data-v-cb375af1]{font-size:22px;color:#ef4444}.modal-title[data-v-cb375af1]{font-size:16px;font-weight:800;color:var(--tb-text);margin:0}.modal-desc[data-v-cb375af1]{font-size:13px;font-weight:500;color:var(--tb-sub);line-height:1.7;margin:0}.modal-desc strong[data-v-cb375af1]{color:var(--tb-text);font-weight:800}.modal-warn[data-v-cb375af1]{font-size:11.5px;color:#ef4444;font-weight:600}.modal-actions[data-v-cb375af1]{display:flex;gap:10px;margin-top:4px;width:100%;justify-content:center}.btn-delete-confirm[data-v-cb375af1]{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;background:#ef4444;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px #ef44444d;transition:all .2s}.btn-delete-confirm[data-v-cb375af1]:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-delete-confirm[data-v-cb375af1]:disabled{opacity:.55;cursor:not-allowed}.delete-error-box[data-v-cb375af1]{display:flex;align-items:flex-start;gap:8px;width:100%;padding:10px 14px;background:#ef444412;border:1.5px solid rgba(239,68,68,.25);border-radius:9px;font-size:12.5px;font-weight:600;color:#dc2626;text-align:left;line-height:1.5}.delete-error-box i[data-v-cb375af1]{font-size:14px;flex-shrink:0;margin-top:1px}.modal-pop-enter-active[data-v-cb375af1]{transition:opacity .2s,transform .2s}.modal-pop-leave-active[data-v-cb375af1]{transition:opacity .15s,transform .15s}.modal-pop-enter-from[data-v-cb375af1],.modal-pop-leave-to[data-v-cb375af1]{opacity:0;transform:scale(.92)}.overlay-fade-enter-active[data-v-cb375af1],.overlay-fade-leave-active[data-v-cb375af1]{transition:opacity .25s ease}.overlay-fade-enter-from[data-v-cb375af1],.overlay-fade-leave-to[data-v-cb375af1]{opacity:0}.drawer-slide-enter-active[data-v-cb375af1]{transition:transform .3s cubic-bezier(.32,.72,0,1)}.drawer-slide-leave-active[data-v-cb375af1]{transition:transform .25s cubic-bezier(.32,.72,0,1)}.drawer-slide-enter-from[data-v-cb375af1],.drawer-slide-leave-to[data-v-cb375af1]{transform:translate(100%)}.fade-enter-active[data-v-cb375af1],.fade-leave-active[data-v-cb375af1]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-cb375af1],.fade-leave-to[data-v-cb375af1]{opacity:0;transform:scale(.95)}@media(max-width:480px){.drawer-panel[data-v-cb375af1]{width:100%}}.page-wrapper[data-v-c29a066d]{padding:0;font-family:Nunito,Barlow,sans-serif}.page-header[data-v-c29a066d]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left[data-v-c29a066d]{display:flex;align-items:center;gap:14px}.page-icon-wrap[data-v-c29a066d]{width:44px;height:44px;border-radius:12px;background:#0ea5e9;display:flex;align-items:center;justify-content:center;flex-shrink:0}.page-icon-wrap i[data-v-c29a066d]{color:#fff;font-size:18px}.page-title[data-v-c29a066d]{font-size:18px;font-weight:800;color:#1e293b;line-height:1.2;margin:0}.page-subtitle[data-v-c29a066d]{font-size:12px;color:#64748b;margin:2px 0 0}.card[data-v-c29a066d]{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.card-toolbar[data-v-c29a066d]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #e2e8f0;flex-wrap:wrap}.toolbar-left[data-v-c29a066d]{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.toolbar-right[data-v-c29a066d]{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box[data-v-c29a066d]{position:relative;min-width:200px;max-width:340px;flex:1}.search-icon[data-v-c29a066d]{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:#64748b;font-size:13px;pointer-events:none}.search-input[data-v-c29a066d]{width:100%;padding:8px 32px 8px 34px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:600;background:#fff;color:#1e293b;outline:none;transition:all .2s}.search-input[data-v-c29a066d]:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91f}.search-input[data-v-c29a066d]::placeholder{color:#64748b;font-weight:500}.search-clear[data-v-c29a066d]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#64748b;font-size:12px;padding:3px;border-radius:4px}.search-clear[data-v-c29a066d]:hover{color:#ef4444}.result-chip[data-v-c29a066d]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:20px;font-size:12px;font-weight:600;color:#0ea5e9;white-space:nowrap}.count-chip[data-v-c29a066d]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px;font-size:12px;font-weight:600;color:#64748b;white-space:nowrap}.table-wrapper[data-v-c29a066d]{overflow-x:auto}.cases-table[data-v-c29a066d]{width:100%;border-collapse:collapse;font-size:12.5px;min-width:1100px}.cases-table thead tr[data-v-c29a066d]{background:#f8fafc;border-bottom:2px solid #e2e8f0}.cases-table th[data-v-c29a066d]{padding:11px 14px;text-align:left;font-size:11px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}.th-num[data-v-c29a066d]{width:44px;text-align:center}.cases-table tbody tr[data-v-c29a066d]{border-bottom:1px solid #e2e8f0;transition:background .15s}.cases-table tbody tr[data-v-c29a066d]:last-child{border-bottom:none}.data-row[data-v-c29a066d]:hover{background:#f8fafc}.cases-table td[data-v-c29a066d]{padding:11px 14px;color:#1e293b;vertical-align:middle}.td-num[data-v-c29a066d]{text-align:center;font-size:11.5px;font-weight:700;color:#64748b}.badge-code[data-v-c29a066d]{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:6px;font-size:11.5px;font-weight:800;color:#0ea5e9;white-space:nowrap}.badge-code i[data-v-c29a066d]{font-size:10px;opacity:.7}.cell-name[data-v-c29a066d]{display:flex;align-items:center;gap:9px}.avatar-circle[data-v-c29a066d]{width:30px;height:30px;border-radius:50%;background:#0ea5e9;color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.name-text[data-v-c29a066d]{font-weight:700;color:#1e293b}.position-text[data-v-c29a066d]{display:flex;align-items:center;gap:5px;font-size:12px;color:#64748b;font-weight:600}.pos-icon[data-v-c29a066d]{font-size:10px;opacity:.6}.location-text[data-v-c29a066d]{display:flex;align-items:center;gap:5px;font-size:12px;color:#64748b;font-weight:600}.loc-icon[data-v-c29a066d]{font-size:10px;color:#ef4444;opacity:.8}.creator-tag[data-v-c29a066d]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:#64748b}.creator-tag i[data-v-c29a066d]{font-size:11px;opacity:.7}.date-cell[data-v-c29a066d]{display:flex;align-items:center;gap:6px;font-size:11.5px;color:#64748b;font-weight:600;white-space:nowrap}.date-icon[data-v-c29a066d]{font-size:11px;opacity:.5}.null-dash[data-v-c29a066d]{color:#cbd5e1;font-size:14px}.action-wrap[data-v-c29a066d]{display:flex;align-items:center;gap:6px}.btn-pdf[data-v-c29a066d]{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:#eab3081f;border:1px solid rgba(234,179,8,.35);border-radius:7px;color:#b45309;font-size:11.5px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-pdf[data-v-c29a066d]:hover:not(:disabled){background:#eab30838;transform:translateY(-1px)}.btn-pdf[data-v-c29a066d]:disabled{opacity:.6;cursor:not-allowed}.btn-pdf i[data-v-c29a066d]{font-size:12px}.btn-delete[data-v-c29a066d]{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:7px;color:#ef4444;font-size:12px;cursor:pointer;transition:all .15s;flex-shrink:0}.btn-delete[data-v-c29a066d]:hover:not(:disabled){background:#ef44442e;transform:translateY(-1px)}.btn-delete[data-v-c29a066d]:disabled{opacity:.5;cursor:not-allowed}.state-cell[data-v-c29a066d]{padding:0!important}.state-content[data-v-c29a066d]{display:flex;flex-direction:column;align-items:center;gap:10px;padding:52px 24px;color:#64748b;font-size:13px;font-weight:600}.empty-icon-wrap[data-v-c29a066d]{width:52px;height:52px;border-radius:50%;background:#f8fafc;border:2px dashed #e2e8f0;display:flex;align-items:center;justify-content:center}.empty-icon-wrap i[data-v-c29a066d]{font-size:20px;color:#64748b;opacity:.5}.empty-title[data-v-c29a066d]{font-size:13.5px;font-weight:700;color:#1e293b}.empty-sub[data-v-c29a066d]{font-size:12px;color:#64748b}.spinner[data-v-c29a066d]{width:28px;height:28px;border:3px solid #e2e8f0;border-top-color:#0ea5e9;border-radius:50%;animation:spin-c29a066d .7s linear infinite}@keyframes spin-c29a066d{to{transform:rotate(360deg)}}.card-footer[data-v-c29a066d]{padding:10px 16px;border-top:1px solid #e2e8f0;background:#f8fafc}.footer-info[data-v-c29a066d]{font-size:12px;color:#64748b;font-weight:600}.fade-enter-active[data-v-c29a066d],.fade-leave-active[data-v-c29a066d]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-c29a066d],.fade-leave-to[data-v-c29a066d]{opacity:0;transform:scale(.95)}.app-root.dark .page-wrapper[data-v-c29a066d]{background:#0f172a;color:#e5e7eb}.app-root.dark .card[data-v-c29a066d]{background:#1a1a2e;border-color:#374151;color:#e5e7eb}.app-root.dark .card-header[data-v-c29a066d]{background:#1a1a2e;border-bottom-color:#374151}.app-root.dark .card-title[data-v-c29a066d]{color:#d1d5db}.app-root.dark .card-sub[data-v-c29a066d]{color:#a0aec0}.app-root.dark table[data-v-c29a066d]{background:#1a1a2e;color:#e5e7eb}.app-root.dark thead[data-v-c29a066d]{background:#0f172a;color:#d1d5db;border-bottom-color:#374151}.app-root.dark tbody tr[data-v-c29a066d]{border-color:#374151}.app-root.dark tbody tr[data-v-c29a066d]:hover{background:#2d3748}.app-root.dark td[data-v-c29a066d]{border-color:#374151;color:#d1d5db}.app-root.dark th[data-v-c29a066d]{color:#d1d5db;border-color:#374151}.app-root.dark .form-control[data-v-c29a066d]{background:#2d3748;border-color:#4b5563;color:#e5e7eb}.app-root.dark .form-control[data-v-c29a066d]::placeholder{color:#9ca3af}.app-root.dark .table-wrap[data-v-c29a066d]{background:#1a1a2e}.app-root.dark .search-input[data-v-c29a066d]{background:#2d3748;border-color:#4b5563;color:#e5e7eb}.app-root.dark .search-input[data-v-c29a066d]::placeholder{color:#9ca3af}.app-root.dark .btn-add[data-v-c29a066d]{background:#3b82f6}.app-root.dark .btn-add[data-v-c29a066d]:hover{background:#2563eb}.app-root.dark button[data-v-c29a066d]{color:#fff}.app-root.dark .empty-icon-wrap[data-v-c29a066d]{background:#2d3748;border-color:#4b5563}.app-root.dark .empty-icon-wrap i[data-v-c29a066d]{color:#6b7280}.app-root.dark .empty-title[data-v-c29a066d]{color:#d1d5db}.app-root.dark .empty-sub[data-v-c29a066d]{color:#a0aec0}.app-root.dark .card-footer[data-v-c29a066d]{background:#2d3748;border-top-color:#374151}.app-root.dark .footer-info[data-v-c29a066d]{color:#a0aec0}.app-root.dark h1[data-v-c29a066d],.app-root.dark h2[data-v-c29a066d],.app-root.dark h3[data-v-c29a066d]{color:#e5e7eb}.app-root.dark p[data-v-c29a066d]{color:#a0aec0}.page-discipline{--primary:#0ea5e9;--primary-dark:#0284c7;--primary-light:#f0f9ff;--primary-border:#bae6fd;--success:#10b981;--success-light:#f0fdf4;--success-border:#86efac;--success-dark:#15803d;--danger:#ef4444;--dark:#1e293b;--gray:#64748b;--border:#d1d5db;--bg:#f8f9fa;--white:#fff;--radius:12px;--shadow:0 2px 8px rgba(0,0,0,.08)}.page-discipline body,.page-discipline{background:var(--bg);min-height:100vh;padding:20px;color:var(--dark);font-size:14px}.page-discipline .container{max-width:1400px;margin:0 auto}.page-discipline .page-header{background:var(--white);padding:25px 30px;border-radius:var(--radius);margin-bottom:25px;box-shadow:var(--shadow);border-left:5px solid var(--primary)}.page-discipline .page-header h1{font-size:26px;font-weight:700;color:var(--dark);margin-bottom:4px;display:flex;align-items:center;gap:12px}.page-discipline .page-header h1 i{color:var(--primary)}.page-discipline .page-header p{color:var(--gray);font-size:14px}.page-discipline .main-grid{display:grid;grid-template-columns:430px 1fr;gap:20px;align-items:start}.page-discipline .card{background:var(--white);border-radius:var(--radius);padding:25px;box-shadow:var(--shadow);border:1px solid var(--primary-border)}.page-discipline .card-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #f1f5f9}.page-discipline .card-header h3{font-size:17px;font-weight:600;color:var(--dark)}.page-discipline .card-header i{font-size:20px;color:var(--primary)}.page-discipline .form-group{margin-bottom:14px}.page-discipline .form-label{display:block;margin-bottom:6px;font-weight:600;color:var(--dark);font-size:13px}.page-discipline .form-control{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:all .2s;background:var(--white);font-family:Noto Sans Lao,Noto Sans Thai,sans-serif;outline:none}.page-discipline .form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #0ea5e91f}.page-discipline .form-control.auto-filled{background:var(--primary-light)!important;border-left:3px solid var(--primary)!important}.page-discipline textarea.form-control{resize:vertical;min-height:80px}.page-discipline .row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.page-discipline .search-wrap{position:relative}.page-discipline .search-wrap .form-control{padding-right:42px}.page-discipline .search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:none;color:var(--primary);font-size:15px;cursor:pointer;padding:4px 6px;border-radius:6px}.page-discipline .search-btn:hover{background:var(--primary-light)}.page-discipline .suggest-dropdown{position:absolute;top:calc(100% + 2px);left:0;right:0;background:#fff;border:1.5px solid var(--primary-border);border-radius:10px;box-shadow:0 8px 24px #0ea5e926;z-index:999;max-height:220px;overflow-y:auto}.page-discipline .suggest-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid #f1f5f9;transition:background .15s}.page-discipline .suggest-item:last-child{border-bottom:none}.page-discipline .suggest-item:hover{background:var(--primary-light)}.page-discipline .suggest-code{font-weight:700;color:var(--primary-dark);min-width:90px;font-size:12px;background:#e0f2fe;padding:2px 7px;border-radius:5px}.page-discipline .suggest-name{flex:1;font-weight:600;color:#1e293b}.page-discipline .suggest-dept{font-size:11px;color:#64748b;white-space:nowrap}.page-discipline .sig-preview-box{margin-top:8px;padding:10px 14px;background:#f0f9ff;border:1.5px solid var(--primary-border);border-radius:10px;font-size:12px;color:#1e293b}.page-discipline .sig-preview-line{display:flex;align-items:center;gap:6px;font-weight:600;color:#374151;margin-bottom:4px}.page-discipline .sig-preview-blank{display:inline-block;width:110px;border-bottom:1.5px solid #64748b;min-height:18px}.page-discipline .sig-preview-label{font-size:11px;color:var(--primary-dark);font-weight:600;padding-left:2px}.page-discipline .btn{padding:11px 22px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-family:Noto Sans Lao,Noto Sans Thai,sans-serif;transition:all .2s}.page-discipline .btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.page-discipline .btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.page-discipline .btn-primary{background:var(--primary);color:var(--white)}.page-discipline .btn-success{background:var(--success);color:var(--white)}.page-discipline .btn-gray{background:#e2e8f0;color:#475569}.page-discipline .btn-sm{padding:8px 16px;font-size:13px}.page-discipline .btn-lg{padding:14px 28px;font-size:15px}.page-discipline .info-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 15px;background:var(--primary-light);border-left:3px solid var(--primary);border-radius:8px;font-size:13px;color:var(--primary-dark);width:100%}.page-discipline .action-row{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid #f1f5f9}.page-discipline .right-panel{display:flex;flex-direction:column;gap:16px}.page-discipline .step-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--primary-border);overflow:hidden}.page-discipline .step-header{padding:16px 22px;border-bottom:2px solid #f1f5f9;display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.page-discipline .step-badge{width:32px;height:32px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.page-discipline .step-title{font-size:15px;font-weight:700;color:var(--dark);flex:1}.page-discipline .step-chevron{color:#94a3b8;font-size:13px;transition:transform .25s}.page-discipline .step-card.active .step-chevron{transform:rotate(180deg)}.page-discipline .step-body{padding:22px 25px;display:none}.page-discipline .step-card.active .step-body{display:block}.page-discipline .two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}.page-discipline .cb-group{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.page-discipline .cb-group input[type=checkbox],.page-discipline .cb-group input[type=radio]{margin-top:3px;width:16px;height:16px;accent-color:var(--primary);flex-shrink:0;cursor:pointer}.page-discipline .cb-label{font-size:13px;color:#374151;line-height:1.6}.page-discipline .asset-calc-box{margin-left:26px;margin-top:6px;padding:16px;background:#f0f9ff;border:1.5px solid var(--primary-border);border-radius:12px;margin-bottom:10px}.page-discipline .calc-row-label{font-size:12px;font-weight:700;color:var(--primary-dark);margin-bottom:12px}.page-discipline .calc-grid-row{display:grid;grid-template-columns:1fr auto 1fr;align-items:center;gap:10px}.page-discipline .calc-cell{background:var(--white);border:1.5px solid var(--primary-border);border-radius:10px;padding:10px 12px}.page-discipline .calc-cell-label{display:block;font-size:11px;font-weight:700;color:var(--primary-dark);margin-bottom:6px}.page-discipline .calc-oper-cell{display:flex;align-items:center;justify-content:center;flex-shrink:0}.page-discipline .calc-oper-badge{background:var(--primary);color:var(--white);font-size:12px;font-weight:800;padding:6px 10px;border-radius:8px;white-space:nowrap}.page-discipline .calc-oper-div{background:#f59e0b}.page-discipline .calc-input{padding:8px 10px!important;font-size:13px!important;width:100%}.page-discipline .calc-result{background:#e0f2fe!important;color:var(--primary-dark)!important;font-weight:700!important;border-color:var(--primary)!important;cursor:default!important}.page-discipline .calc-result-row{display:grid;grid-template-columns:1fr 1fr;gap:10px;margin-top:10px}.page-discipline .calc-equal-box{background:var(--success-light);border:2px solid var(--success-border);border-radius:10px;padding:10px 14px;display:flex;align-items:center;gap:8px;min-height:52px}.page-discipline .calc-equal-empty{background:#f8fafc;border-color:#e2e8f0;justify-content:center}.page-discipline .calc-equal-label{font-size:11px;font-weight:700;color:var(--success-dark);white-space:nowrap}.page-discipline .calc-equal-value{font-size:20px;font-weight:800;color:var(--success-dark);flex:1;text-align:right}.page-discipline .calc-equal-unit{font-size:10px;font-weight:600;color:var(--success);white-space:nowrap;padding-left:4px}.page-discipline .calc-date-field{background:var(--white);border:1.5px solid var(--primary-border);border-radius:10px;padding:10px 12px}.page-discipline .calc-summary{display:flex;align-items:center;gap:8px;background:var(--success-light);border:1px solid var(--success-border);border-radius:8px;padding:8px 12px;font-size:12px;color:var(--success-dark);margin-top:10px}.page-discipline .calc-summary i{color:var(--success);flex-shrink:0}.page-discipline .slide-down-enter-active{transition:all .3s ease;max-height:600px}.page-discipline .slide-down-leave-active{transition:all .2s ease}.page-discipline .slide-down-enter-from{max-height:0;opacity:0;transform:translateY(-8px);overflow:hidden}.page-discipline .slide-down-leave-to{max-height:0;opacity:0;overflow:hidden}.page-discipline .punish5-input{border:1.5px solid var(--primary)!important;background:var(--primary-light)!important}.page-discipline .punish5-preview{margin-top:8px;padding:9px 13px;background:#f0fdf4;border:1px solid #86efac;border-left:3px solid #10b981;border-radius:8px;font-size:12px;color:#166534;line-height:1.7}.page-discipline .fade-enter-active,.page-discipline .fade-leave-active{transition:opacity .2s,transform .2s}.page-discipline .fade-enter-from,.page-discipline .fade-leave-to{opacity:0;transform:translateY(-6px)}.page-discipline .preview-info{background:var(--primary-light);border-left:3px solid var(--primary);border-radius:8px;padding:10px 16px;font-size:13px;color:var(--primary-dark);margin-bottom:16px;display:flex;align-items:center;gap:8px}.page-discipline .preview-box{background:#f8fafc;border:1px solid var(--primary-border);border-radius:8px;padding:18px;min-height:120px;font-size:13px;line-height:2;color:#374151}.page-discipline .section-divider{border:none;border-top:1.5px solid #f1f5f9;margin:6px 0 14px}.page-discipline .save-status{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;font-size:13px;font-weight:600;margin-top:14px}.page-discipline .save-status.success{background:var(--success-light);border:1px solid var(--success-border);color:var(--success-dark)}.page-discipline .save-status.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}@media(max-width:1100px){.page-discipline .main-grid{grid-template-columns:1fr}}@media(max-width:700px){.page-discipline .row-2,.page-discipline .two-col,.page-discipline .calc-grid-row,.page-discipline .calc-result-row{grid-template-columns:1fr}.page-discipline .calc-oper-cell{justify-content:flex-start}.page-discipline .card,.page-discipline .step-body{padding:15px}}.page-discipline.dark-mode{--primary:#3b82f6;--primary-dark:#1e40af;--primary-light:#1e40af;--border:#374151;--bg:#1a1a2e;--white:#1f2937;--dark:#f0f0f0;--gray:#a0aec0}.page-discipline.dark-mode .page-header{background:#2d3748;border-left-color:#3b82f6}.page-discipline.dark-mode .card{background:#2d3748;border-color:#374151}.page-discipline.dark-mode .form-control{background:#374151;border-color:#4b5563;color:#e5e7eb}.page-discipline.dark-mode .form-control::placeholder{color:#9ca3af}.page-discipline.dark-mode .form-label{color:#d1d5db}.page-discipline.dark-mode .section-divider{border-top-color:#374151}.page-discipline.dark-mode .suggest-dropdown{background:#374151;border-color:#4b5563}.page-discipline.dark-mode .suggest-item{color:#d1d5db;border-color:#4b5563}.page-discipline.dark-mode .suggest-item:hover{background:#4b5563}.page-discipline.dark-mode .step-card{background:#2d3748;border-color:#374151}.page-discipline.dark-mode .step-body{border-color:#374151}.page-discipline.dark-mode .cb-label{color:#d1d5db}.page-discipline.dark-mode .asset-calc-box{background:#1a1a2e;border-color:#3b82f6}.page-discipline.dark-mode .calc-cell,.page-discipline.dark-mode .preview-box{background:#374151;border-color:#4b5563;color:#d1d5db}.page-discipline.dark-mode .info-badge{background:#1e3a8a;color:#bfdbfe;border-left-color:#3b82f6}.page-discipline.dark-mode .btn-dark-toggle{background:transparent;color:#9ca3af;padding:8px 12px;border-radius:6px;cursor:pointer;border:none;transition:all .2s}.page-discipline.dark-mode .btn-dark-toggle:hover{background:#9ca3af1a}.page-discipline.dark-mode .btn-sm{color:#1a1a2e}.page-discipline.dark-mode .save-status{background:#1e293b;border-color:#374151;color:#d1d5db}.page-discipline.dark-mode .save-status.success{background:#064e3b;border-color:#059669;color:#d1fae5}.page-discipline.dark-mode h1,.page-discipline.dark-mode h3,.page-discipline.dark-mode h4{color:#e5e7eb}.page-discipline.dark-mode p{color:#a0aec0}.page-discipline.dark-mode body{background:#0f172a;color:#f0f0f0}.btn-dark-toggle{background:transparent;color:#6b7280;padding:8px 12px;border-radius:6px;cursor:pointer;border:none;transition:all .2s}.btn-dark-toggle:hover{background:#6b72801a}.app-root.dark .page-discipline{background:#0f172a;color:#e5e7eb}.app-root.dark .page-discipline .page-header{background:#1a1a2e;border-left-color:#3b82f6}.app-root.dark .page-discipline .card{background:#1a1a2e;border-color:#374151}.app-root.dark .page-discipline .form-control{background:#2d3748;border-color:#4b5563;color:#e5e7eb}.app-root.dark .page-discipline .form-control::placeholder{color:#9ca3af}.app-root.dark .page-discipline .form-label{color:#d1d5db}.app-root.dark .page-discipline h1,.app-root.dark .page-discipline h3{color:#e5e7eb}.app-root.dark .page-discipline p{color:#a0aec0}.app-root.dark .page-discipline .step-card{background:#1a1a2e;border-color:#374151}.app-root.dark .page-discipline .section-divider{border-top-color:#374151}.app-root.dark .page-discipline .suggest-dropdown{background:#2d3748;border-color:#4b5563}.app-root.dark .page-discipline .suggest-item{color:#d1d5db}.app-root.dark .page-discipline .suggest-item:hover{background:#374151}.app-root.dark .page-discipline .info-badge{background:#1e3a8a;color:#bfdbfe;border-left-color:#3b82f6}.app-root.dark .page-discipline .calc-cell{background:#2d3748;border-color:#4b5563;color:#d1d5db}.app-root.dark .page-discipline .btn{color:#fff}.page-wrapper[data-v-48ae9afd]{padding:0;font-family:Nunito,Barlow,sans-serif;position:relative}.page-header[data-v-48ae9afd]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left[data-v-48ae9afd]{display:flex;align-items:center;gap:14px}.page-icon-wrap[data-v-48ae9afd]{width:44px;height:44px;border-radius:12px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 4px 14px var(--accent-glow);flex-shrink:0}.page-icon-wrap i[data-v-48ae9afd]{color:#fff;font-size:18px}.page-title[data-v-48ae9afd]{font-size:18px;font-weight:800;color:var(--tb-text);line-height:1.2;margin:0;transition:color .3s}.page-subtitle[data-v-48ae9afd]{font-size:12px;color:var(--tb-sub);margin:2px 0 0;transition:color .3s}.btn-add[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:8px;padding:9px 18px;background:var(--accent);color:#fff;border:none;border-radius:10px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 4px 14px var(--accent-glow);transition:all .2s}.btn-add[data-v-48ae9afd]:hover{background:var(--accent-dark);transform:translateY(-1px)}.btn-add i[data-v-48ae9afd]{font-size:12px}.card[data-v-48ae9afd]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:14px;box-shadow:var(--shadow-sm);overflow:hidden;transition:background .3s,border-color .3s}.card-toolbar[data-v-48ae9afd]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid var(--tb-border);flex-wrap:wrap;transition:border-color .3s}.toolbar-left[data-v-48ae9afd]{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.toolbar-right[data-v-48ae9afd]{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box[data-v-48ae9afd]{position:relative;min-width:200px;max-width:340px;flex:1}.search-icon[data-v-48ae9afd]{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:var(--tb-sub);font-size:13px;pointer-events:none}.search-input[data-v-48ae9afd]{width:100%;padding:8px 32px 8px 34px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s}.search-input[data-v-48ae9afd]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.search-input[data-v-48ae9afd]::placeholder{color:var(--tb-sub);font-weight:500}.search-clear[data-v-48ae9afd]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:12px;padding:3px;border-radius:4px;transition:color .2s}.search-clear[data-v-48ae9afd]:hover{color:#ef4444}.result-chip[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:20px;font-size:12px;font-weight:600;color:var(--accent);white-space:nowrap}.count-chip[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:var(--sb-search-bg);border:1px solid var(--tb-border);border-radius:20px;font-size:12px;font-weight:600;color:var(--tb-sub);white-space:nowrap}.table-wrapper[data-v-48ae9afd]{overflow-x:auto}.sig-table[data-v-48ae9afd]{width:100%;border-collapse:collapse;font-size:12.5px;min-width:700px}.sig-table thead tr[data-v-48ae9afd]{background:var(--sb-search-bg);border-bottom:2px solid var(--tb-border)}.sig-table th[data-v-48ae9afd]{padding:11px 14px;text-align:left;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}.th-num[data-v-48ae9afd]{width:44px;text-align:center}.sig-table tbody tr[data-v-48ae9afd]{border-bottom:1px solid var(--tb-border);transition:background .15s}.sig-table tbody tr[data-v-48ae9afd]:last-child{border-bottom:none}.data-row[data-v-48ae9afd]:hover{background:var(--sb-hover)}.sig-table td[data-v-48ae9afd]{padding:11px 14px;color:var(--tb-text);vertical-align:middle}.td-num[data-v-48ae9afd]{text-align:center;font-size:11.5px;font-weight:700;color:var(--tb-sub)}.cell-name[data-v-48ae9afd]{display:flex;align-items:center;gap:9px}.avatar-circle[data-v-48ae9afd]{width:30px;height:30px;border-radius:50%;background:var(--accent);color:#fff;font-size:12px;display:flex;align-items:center;justify-content:center;flex-shrink:0;box-shadow:0 2px 8px var(--accent-glow)}.name-text[data-v-48ae9afd]{font-weight:700;color:var(--tb-text)}.sig-cell[data-v-48ae9afd]{display:flex;align-items:center}.sig-thumb[data-v-48ae9afd]{height:32px;max-width:90px;object-fit:contain;border-radius:5px;border:1px solid var(--tb-border);background:var(--sb-search-bg);padding:2px 4px;transition:border-color .2s,transform .2s;cursor:zoom-in}.sig-thumb[data-v-48ae9afd]:hover{border-color:var(--accent);transform:scale(1.08)}.cell-detail[data-v-48ae9afd]{max-width:260px}.detail-text[data-v-48ae9afd]{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;font-size:12px;color:var(--tb-sub);font-weight:500;line-height:1.5}.creator-tag[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:5px;font-size:12px;font-weight:600;color:var(--tb-sub)}.date-cell[data-v-48ae9afd]{display:flex;align-items:center;gap:6px;font-size:11.5px;color:var(--tb-sub);font-weight:600;white-space:nowrap}.date-icon[data-v-48ae9afd]{font-size:11px;opacity:.5}.null-dash[data-v-48ae9afd]{color:var(--tb-border);font-size:14px}.state-cell[data-v-48ae9afd]{padding:0!important}.state-content[data-v-48ae9afd]{display:flex;flex-direction:column;align-items:center;gap:10px;padding:52px 24px;color:var(--tb-sub);font-size:13px;font-weight:600}.empty-icon-wrap[data-v-48ae9afd]{width:52px;height:52px;border-radius:50%;background:var(--sb-search-bg);border:2px dashed var(--tb-border);display:flex;align-items:center;justify-content:center}.empty-icon-wrap i[data-v-48ae9afd]{font-size:20px;color:var(--tb-sub);opacity:.5}.empty-title[data-v-48ae9afd]{font-size:13.5px;font-weight:700;color:var(--tb-text)}.empty-sub[data-v-48ae9afd]{font-size:12px;color:var(--tb-sub)}.btn-add-empty[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;margin-top:4px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;transition:background .2s}.btn-add-empty[data-v-48ae9afd]:hover{background:var(--accent-dark)}.spinner[data-v-48ae9afd]{width:28px;height:28px;border:3px solid var(--tb-border);border-top-color:var(--accent);border-radius:50%;animation:spin-48ae9afd .7s linear infinite}@keyframes spin-48ae9afd{to{transform:rotate(360deg)}}.card-footer[data-v-48ae9afd]{padding:10px 16px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg)}.th-actions[data-v-48ae9afd]{text-align:center;width:90px}.td-actions[data-v-48ae9afd]{text-align:center}.actions-wrap[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:6px}.btn-action[data-v-48ae9afd]{width:30px;height:30px;border-radius:7px;border:none;cursor:pointer;display:inline-flex;align-items:center;justify-content:center;font-size:12px;transition:all .18s}.btn-edit[data-v-48ae9afd]{background:#1976d21a;color:var(--accent);border:1px solid rgba(25,118,210,.2)}.btn-edit[data-v-48ae9afd]:hover{background:var(--accent);color:#fff;transform:translateY(-1px)}.btn-delete[data-v-48ae9afd]{background:#ef444414;color:#ef4444;border:1px solid rgba(239,68,68,.18)}.btn-delete[data-v-48ae9afd]:hover{background:#ef4444;color:#fff;transform:translateY(-1px)}.drawer-overlay[data-v-48ae9afd]{position:fixed;inset:0;background:#00000059;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);z-index:400}.drawer-panel[data-v-48ae9afd]{position:fixed;top:0;right:0;bottom:0;width:420px;max-width:100vw;background:var(--tb-bg);border-left:1px solid var(--tb-border);box-shadow:-8px 0 40px #00000024;z-index:500;display:flex;flex-direction:column;overflow:hidden}.drawer-header[data-v-48ae9afd]{display:flex;align-items:center;justify-content:space-between;padding:18px 20px;border-bottom:1px solid var(--tb-border);flex-shrink:0}.drawer-header-left[data-v-48ae9afd]{display:flex;align-items:center;gap:12px}.drawer-icon[data-v-48ae9afd]{width:38px;height:38px;border-radius:10px;background:var(--accent);display:flex;align-items:center;justify-content:center;box-shadow:0 3px 10px var(--accent-glow);flex-shrink:0}.drawer-icon i[data-v-48ae9afd]{color:#fff;font-size:15px}.drawer-icon-edit[data-v-48ae9afd]{background:#f59e0b;box-shadow:0 3px 10px #f59e0b59}.drawer-title[data-v-48ae9afd]{font-size:15px;font-weight:800;color:var(--tb-text);margin:0}.drawer-sub[data-v-48ae9afd]{font-size:11.5px;color:var(--tb-sub);margin:1px 0 0}.drawer-close[data-v-48ae9afd]{width:32px;height:32px;border-radius:8px;background:none;border:none;cursor:pointer;color:var(--tb-sub);font-size:15px;display:flex;align-items:center;justify-content:center;transition:all .2s}.drawer-close[data-v-48ae9afd]:hover{background:#ef44441a;color:#ef4444}.drawer-body[data-v-48ae9afd]{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:20px}.drawer-body[data-v-48ae9afd]::-webkit-scrollbar{width:3px}.drawer-body[data-v-48ae9afd]::-webkit-scrollbar-thumb{background:var(--tb-border);border-radius:3px}.form-section[data-v-48ae9afd]{display:flex;flex-direction:column;gap:12px}.form-section-label[data-v-48ae9afd]{display:flex;align-items:center;gap:7px;font-size:11px;font-weight:800;color:var(--tb-sub);text-transform:uppercase;letter-spacing:.7px;padding-bottom:8px;border-bottom:1px solid var(--tb-border)}.form-section-label i[data-v-48ae9afd]{font-size:11px;color:var(--accent)}.form-group[data-v-48ae9afd]{display:flex;flex-direction:column;gap:5px}.form-label[data-v-48ae9afd]{font-size:11.5px;font-weight:700;color:var(--tb-text)}.form-label.required[data-v-48ae9afd]:after{content:" *";color:#ef4444}.form-input[data-v-48ae9afd]{width:100%;padding:9px 12px;border:2px solid var(--tb-border);border-radius:8px;font-size:13px;font-family:inherit;font-weight:600;background:var(--sb-search-bg);color:var(--tb-text);outline:none;transition:all .2s;box-sizing:border-box}.form-input[data-v-48ae9afd]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-input[data-v-48ae9afd]::placeholder{color:var(--tb-sub);font-weight:500;opacity:.8}.sig-upload-zone[data-v-48ae9afd]{position:relative;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:6px;padding:20px 16px;border:2px dashed var(--tb-border);border-radius:10px;background:var(--sb-search-bg);cursor:pointer;transition:all .2s;min-height:100px}.sig-upload-zone[data-v-48ae9afd]:hover{border-color:var(--accent);background:var(--accent-glow2)}.sig-upload-zone.has-preview[data-v-48ae9afd]{padding:8px;border-style:solid;border-color:var(--accent);background:var(--accent-glow2)}.sig-upload-zone.is-uploading[data-v-48ae9afd]{cursor:not-allowed;opacity:.7}.sig-upload-icon[data-v-48ae9afd]{width:38px;height:38px;border-radius:10px;background:#1976d21a;display:flex;align-items:center;justify-content:center}.sig-upload-icon i[data-v-48ae9afd]{font-size:16px;color:var(--accent)}.sig-upload-text[data-v-48ae9afd]{font-size:12.5px;font-weight:700;color:var(--tb-text)}.sig-upload-hint[data-v-48ae9afd]{font-size:11px;color:var(--tb-sub)}.sig-preview-img[data-v-48ae9afd]{max-height:80px;max-width:100%;object-fit:contain;border-radius:6px}.sig-remove-btn[data-v-48ae9afd]{position:absolute;top:6px;right:6px;width:24px;height:24px;border-radius:50%;background:#ef4444;color:#fff;border:none;cursor:pointer;font-size:11px;display:flex;align-items:center;justify-content:center;transition:background .2s;box-shadow:0 2px 6px #ef444466}.sig-remove-btn[data-v-48ae9afd]:hover{background:#dc2626}.sig-error-box[data-v-48ae9afd]{display:flex;align-items:center;gap:7px;padding:8px 12px;margin-top:4px;background:#ef444412;border:1.5px solid rgba(239,68,68,.22);border-radius:8px;font-size:12px;font-weight:600;color:#dc2626}.sig-error-box i[data-v-48ae9afd]{font-size:13px;flex-shrink:0}.form-textarea[data-v-48ae9afd]{width:100%;padding:9px 12px;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:500;background:var(--sb-search-bg);color:var(--tb-text);outline:none;resize:vertical;line-height:1.6;transition:all .2s}.form-textarea[data-v-48ae9afd]:focus{border-color:var(--accent);background:var(--tb-bg);box-shadow:0 0 0 3px var(--accent-glow2)}.form-textarea[data-v-48ae9afd]::placeholder{color:var(--tb-sub);font-weight:400}.drawer-footer[data-v-48ae9afd]{display:flex;align-items:center;justify-content:flex-end;gap:10px;padding:14px 20px;border-top:1px solid var(--tb-border);background:var(--sb-search-bg);flex-shrink:0}.btn-cancel[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:7px;padding:8px 16px;background:none;border:1.5px solid var(--tb-border);border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;color:var(--tb-sub);cursor:pointer;transition:all .2s}.btn-cancel[data-v-48ae9afd]:hover{border-color:#ef4444;color:#ef4444}.btn-save[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:8px;padding:8px 20px;background:var(--accent);color:#fff;border:none;border-radius:8px;font-size:12.5px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px var(--accent-glow);transition:all .2s}.btn-save[data-v-48ae9afd]:hover:not(:disabled){background:var(--accent-dark);transform:translateY(-1px)}.btn-save[data-v-48ae9afd]:disabled{opacity:.55;cursor:not-allowed}.btn-spinner[data-v-48ae9afd]{width:14px;height:14px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin-48ae9afd .6s linear infinite}.modal-overlay[data-v-48ae9afd]{position:fixed;inset:0;background:#0006;-webkit-backdrop-filter:blur(3px);backdrop-filter:blur(3px);z-index:600;display:flex;align-items:center;justify-content:center;padding:20px}.modal-box[data-v-48ae9afd]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:16px;box-shadow:0 20px 60px #0003;padding:28px 28px 24px;width:100%;max-width:360px;display:flex;flex-direction:column;align-items:center;gap:12px;text-align:center}.modal-icon-wrap[data-v-48ae9afd]{width:52px;height:52px;border-radius:50%;background:#ef44441a;border:2px solid rgba(239,68,68,.2);display:flex;align-items:center;justify-content:center;margin-bottom:4px}.modal-icon-wrap i[data-v-48ae9afd]{font-size:22px;color:#ef4444}.modal-title[data-v-48ae9afd]{font-size:16px;font-weight:800;color:var(--tb-text);margin:0}.modal-desc[data-v-48ae9afd]{font-size:13px;font-weight:500;color:var(--tb-sub);line-height:1.7;margin:0}.modal-desc strong[data-v-48ae9afd]{color:var(--tb-text);font-weight:800}.modal-warn[data-v-48ae9afd]{font-size:11.5px;color:#ef4444;font-weight:600}.modal-actions[data-v-48ae9afd]{display:flex;gap:10px;margin-top:4px;width:100%;justify-content:center}.btn-delete-confirm[data-v-48ae9afd]{display:inline-flex;align-items:center;gap:7px;padding:9px 20px;background:#ef4444;color:#fff;border:none;border-radius:9px;font-size:13px;font-weight:700;font-family:inherit;cursor:pointer;box-shadow:0 3px 12px #ef44444d;transition:all .2s}.btn-delete-confirm[data-v-48ae9afd]:hover:not(:disabled){background:#dc2626;transform:translateY(-1px)}.btn-delete-confirm[data-v-48ae9afd]:disabled{opacity:.55;cursor:not-allowed}.delete-error-box[data-v-48ae9afd]{display:flex;align-items:flex-start;gap:8px;width:100%;padding:10px 14px;background:#ef444412;border:1.5px solid rgba(239,68,68,.25);border-radius:9px;font-size:12.5px;font-weight:600;color:#dc2626;text-align:left;line-height:1.5}.delete-error-box i[data-v-48ae9afd]{font-size:14px;flex-shrink:0;margin-top:1px}.modal-pop-enter-active[data-v-48ae9afd]{transition:opacity .2s,transform .2s}.modal-pop-leave-active[data-v-48ae9afd]{transition:opacity .15s,transform .15s}.modal-pop-enter-from[data-v-48ae9afd],.modal-pop-leave-to[data-v-48ae9afd]{opacity:0;transform:scale(.92)}.overlay-fade-enter-active[data-v-48ae9afd],.overlay-fade-leave-active[data-v-48ae9afd]{transition:opacity .25s ease}.overlay-fade-enter-from[data-v-48ae9afd],.overlay-fade-leave-to[data-v-48ae9afd]{opacity:0}.drawer-slide-enter-active[data-v-48ae9afd]{transition:transform .3s cubic-bezier(.32,.72,0,1)}.drawer-slide-leave-active[data-v-48ae9afd]{transition:transform .25s cubic-bezier(.32,.72,0,1)}.drawer-slide-enter-from[data-v-48ae9afd],.drawer-slide-leave-to[data-v-48ae9afd]{transform:translate(100%)}.fade-enter-active[data-v-48ae9afd],.fade-leave-active[data-v-48ae9afd]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-48ae9afd],.fade-leave-to[data-v-48ae9afd]{opacity:0;transform:scale(.95)}@media(max-width:480px){.drawer-panel[data-v-48ae9afd]{width:100%}}*{margin:0;padding:0;box-sizing:border-box;font-family:Noto Sans Lao,Noto Sans Thai,sans-serif}.page-verbal{--primary:#f97316;--primary-dark:#c2410c;--primary-light:#fff7ed;--primary-border:#fed7aa;--success:#10b981;--success-light:#f0fdf4;--success-border:#86efac;--success-dark:#15803d;--danger:#ef4444;--dark:#1e293b;--gray:#64748b;--border:#d1d5db;--bg:#f8f9fa;--white:#fff;--radius:12px;--shadow:0 2px 8px rgba(0,0,0,.08)}.page-verbal{background:var(--bg);min-height:100vh;padding:20px;color:var(--dark);font-size:14px}.page-verbal .container{max-width:1400px;margin:0 auto}.page-verbal .page-header{background:var(--white);padding:25px 30px;border-radius:var(--radius);margin-bottom:25px;box-shadow:var(--shadow);border-left:5px solid var(--primary)}.page-verbal .page-header h1{font-size:26px;font-weight:700;color:var(--dark);margin-bottom:4px;display:flex;align-items:center;gap:12px}.page-verbal .page-header h1 i{color:var(--primary)}.page-verbal .page-header p{color:var(--gray);font-size:14px}.page-verbal .main-grid{display:grid;grid-template-columns:430px 1fr;gap:20px;align-items:start}.page-verbal .card{background:var(--white);border-radius:var(--radius);padding:25px;box-shadow:var(--shadow);border:1px solid var(--primary-border)}.page-verbal .card-header{display:flex;align-items:center;gap:10px;margin-bottom:20px;padding-bottom:15px;border-bottom:2px solid #fff3e0}.page-verbal .card-header h3{font-size:17px;font-weight:600;color:var(--dark)}.page-verbal .card-header i{font-size:20px;color:var(--primary)}.page-verbal .form-group{margin-bottom:14px}.page-verbal .form-label{display:block;margin-bottom:6px;font-weight:600;color:var(--dark);font-size:13px}.page-verbal .form-control{width:100%;padding:10px 14px;border:1px solid var(--border);border-radius:8px;font-size:14px;transition:all .2s;background:var(--white);font-family:Noto Sans Lao,Noto Sans Thai,sans-serif;outline:none}.page-verbal .form-control:focus{border-color:var(--primary);box-shadow:0 0 0 3px #f9731624}.page-verbal .form-control.auto-filled{background:var(--primary-light)!important;border-left:3px solid var(--primary)!important}.page-verbal textarea.form-control{resize:vertical;min-height:80px}.page-verbal .row-2{display:grid;grid-template-columns:1fr 1fr;gap:14px}.page-verbal .search-wrap{position:relative}.page-verbal .search-wrap .form-control{padding-right:42px}.page-verbal .search-btn{position:absolute;right:8px;top:50%;transform:translateY(-50%);border:none;background:none;color:var(--primary);font-size:15px;cursor:pointer;padding:4px 6px;border-radius:6px}.page-verbal .search-btn:hover{background:var(--primary-light)}.page-verbal .suggest-dropdown{position:absolute;top:calc(100% + 2px);left:0;right:0;background:#fff;border:1.5px solid var(--primary-border);border-radius:10px;box-shadow:0 8px 24px #f9731626;z-index:999;max-height:220px;overflow-y:auto}.page-verbal .suggest-item{display:flex;align-items:center;gap:10px;padding:10px 14px;cursor:pointer;font-size:13px;border-bottom:1px solid #fff3e0;transition:background .15s}.page-verbal .suggest-item:last-child{border-bottom:none}.page-verbal .suggest-item:hover{background:var(--primary-light)}.page-verbal .suggest-code{font-weight:700;color:var(--primary-dark);min-width:90px;font-size:12px;background:#ffedd5;padding:2px 7px;border-radius:5px}.page-verbal .suggest-name{flex:1;font-weight:600;color:#1e293b}.page-verbal .suggest-dept{font-size:11px;color:#64748b;white-space:nowrap}.page-verbal .sig-preview-box{margin-top:8px;padding:10px 14px;background:var(--primary-light);border:1.5px solid var(--primary-border);border-radius:10px;font-size:12px;color:#1e293b}.page-verbal .sig-preview-line{display:flex;align-items:center;gap:6px;font-weight:600;color:#374151;margin-bottom:4px}.page-verbal .sig-preview-blank{display:inline-block;width:110px;border-bottom:1.5px solid #64748b;min-height:18px}.page-verbal .sig-preview-label{font-size:11px;color:var(--primary-dark);font-weight:600;padding-left:2px}.page-verbal .btn{padding:11px 22px;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;display:inline-flex;align-items:center;gap:8px;font-family:Noto Sans Lao,Noto Sans Thai,sans-serif;transition:all .2s;text-decoration:none}.page-verbal .btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #0000001f}.page-verbal .btn:disabled{opacity:.65;cursor:not-allowed;transform:none}.page-verbal .btn-primary{background:var(--primary);color:var(--white)}.page-verbal .btn-success{background:var(--success);color:var(--white)}.page-verbal .btn-gray{background:#e2e8f0;color:#475569}.page-verbal .btn-sm{padding:8px 16px;font-size:13px}.page-verbal .btn-lg{padding:14px 28px;font-size:15px}.page-verbal .info-badge{display:inline-flex;align-items:center;gap:8px;padding:10px 15px;background:var(--primary-light);border-left:3px solid var(--primary);border-radius:8px;font-size:13px;color:var(--primary-dark);width:100%}.page-verbal .action-row{display:flex;justify-content:flex-end;gap:10px;margin-top:20px;padding-top:16px;border-top:1px solid #fff3e0}.page-verbal .right-panel{display:flex;flex-direction:column;gap:16px}.page-verbal .step-card{background:var(--white);border-radius:var(--radius);box-shadow:var(--shadow);border:1px solid var(--primary-border);overflow:hidden}.page-verbal .step-header{padding:16px 22px;border-bottom:2px solid #fff3e0;display:flex;align-items:center;gap:12px;cursor:pointer;-webkit-user-select:none;user-select:none}.page-verbal .step-badge{width:32px;height:32px;border-radius:50%;background:var(--primary);color:var(--white);display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;flex-shrink:0}.page-verbal .step-title{font-size:15px;font-weight:700;color:var(--dark);flex:1}.page-verbal .step-chevron{color:#94a3b8;font-size:13px;transition:transform .25s}.page-verbal .step-card.active .step-chevron{transform:rotate(180deg)}.page-verbal .step-body{padding:22px 25px;display:none}.page-verbal .step-card.active .step-body{display:block}.page-verbal .two-col{display:grid;grid-template-columns:1fr 1fr;gap:22px;align-items:start}.page-verbal .cb-group{display:flex;align-items:flex-start;gap:10px;margin-bottom:10px}.page-verbal .cb-group input[type=checkbox],.page-verbal .cb-group input[type=radio]{margin-top:3px;width:16px;height:16px;accent-color:var(--primary);flex-shrink:0;cursor:pointer}.page-verbal .cb-label{font-size:13px;color:#374151;line-height:1.6}.page-verbal .punish5-input{border:1.5px solid var(--primary)!important;background:var(--primary-light)!important}.page-verbal .punish5-preview{margin-top:8px;padding:9px 13px;background:#f0fdf4;border:1px solid #86efac;border-left:3px solid #10b981;border-radius:8px;font-size:12px;color:#166534;line-height:1.7}.page-verbal .fade-enter-active,.page-verbal .fade-leave-active{transition:opacity .2s,transform .2s}.page-verbal .fade-enter-from,.page-verbal .fade-leave-to{opacity:0;transform:translateY(-6px)}.page-verbal .preview-info{background:var(--primary-light);border-left:3px solid var(--primary);border-radius:8px;padding:10px 16px;font-size:13px;color:var(--primary-dark);margin-bottom:16px;display:flex;align-items:center;gap:8px}.page-verbal .preview-box{background:#fffaf7;border:1px solid var(--primary-border);border-radius:8px;padding:18px;min-height:120px;font-size:13px;line-height:2;color:#374151}.page-verbal .section-divider{border:none;border-top:1.5px solid #fff3e0;margin:6px 0 14px}.page-verbal .save-status{display:flex;align-items:center;gap:8px;padding:12px 16px;border-radius:8px;font-size:13px;font-weight:600;margin-top:14px}.page-verbal .save-status.success{background:var(--success-light);border:1px solid var(--success-border);color:var(--success-dark)}.page-verbal .save-status.error{background:#fef2f2;border:1px solid #fecaca;color:#991b1b}@media(max-width:1100px){.page-verbal .main-grid{grid-template-columns:1fr}}@media(max-width:700px){.page-verbal .row-2,.page-verbal .two-col{grid-template-columns:1fr}.page-verbal .card,.page-verbal .step-body{padding:15px}}.app-root.dark .page-verbal{--primary:#3b82f6;--primary-dark:#1e40af;--primary-light:#1e3a8a;--primary-border:#2563eb;--success:#10b981;--success-light:#064e3b;--success-border:#059669;--success-dark:#d1fae5;--white:#1f2937;--bg:#0f172a;--dark:#e5e7eb;--gray:#a0aec0}.app-root.dark .page-verbal{background:#0f172a;color:#e5e7eb}.app-root.dark .page-verbal .card{background:#1a1a2e;border-color:#374151;box-shadow:0 2px 8px #0000004d}.app-root.dark .page-verbal .form-control{background:#2d3748;border-color:#4b5563;color:#e5e7eb}.app-root.dark .page-verbal .form-control::placeholder{color:#9ca3af}.app-root.dark .page-verbal .form-label,.app-root.dark .page-verbal .form-group{color:#d1d5db}.app-root.dark .page-verbal h1,.app-root.dark .page-verbal h3{color:#e5e7eb}.app-root.dark .page-verbal p{color:#a0aec0}.app-root.dark .page-verbal .page-header{background:#1a1a2e;border-left-color:#3b82f6}.app-root.dark .page-verbal .page-header h1 i{color:#3b82f6}.app-root.dark .page-verbal .card-header{border-bottom-color:#374151}.app-root.dark .page-verbal .card-header h3{color:#d1d5db}.app-root.dark .page-verbal .card-header i{color:#3b82f6}.app-root.dark .page-verbal .step-card{background:#1a1a2e;border-color:#374151}.app-root.dark .page-verbal .step-header{border-bottom-color:#374151}.app-root.dark .page-verbal .step-header{text-decoration:none}.app-root.dark .page-verbal .step-badge{background:#3b82f6}.app-root.dark .page-verbal .step-title{color:#e5e7eb}.app-root.dark .page-verbal .step-chevron{color:#6b7280}.app-root.dark .page-verbal input[type=checkbox],.app-root.dark .page-verbal input[type=radio]{accent-color:#3b82f6}.app-root.dark .page-verbal .info-badge{background:#1e3a8a;border-left-color:#3b82f6;color:#bfdbfe}.app-root.dark .page-verbal .preview-box{background:#2d3748;border-color:#4b5563;color:#e5e7eb}.app-root.dark .page-verbal .suggest-dropdown{background:#2d3748;border-color:#4b5563}.app-root.dark .page-verbal .suggest-item{color:#d1d5db;border-color:#4b5563}.app-root.dark .page-verbal .suggest-item:hover{background:#374151}.app-root.dark .page-verbal .btn-primary{background:#3b82f6;color:#fff}.app-root.dark .page-verbal .btn-primary:hover{background:#2563eb}.app-root.dark .page-verbal .btn-gray{background:#4b5563;color:#d1d5db}.app-root.dark .page-verbal .btn-gray:hover{background:#5a6678}.app-root.dark .page-verbal .section-divider{border-top-color:#374151}.app-root.dark .page-verbal .save-status{background:#1e293b;border-color:#374151;color:#d1d5db}.app-root.dark .page-verbal .save-status.success{background:#064e3b;border-color:#059669;color:#d1fae5}.app-root.dark .page-verbal .save-status.error{background:#7f1d1d;border-color:#ef4444;color:#fee2e2}.page-wrapper[data-v-f53e6684]{padding:0;font-family:Noto Sans Lao,Noto Sans Thai,Nunito,Barlow,sans-serif}.page-header[data-v-f53e6684]{display:flex;align-items:center;justify-content:space-between;margin-bottom:20px;flex-wrap:wrap;gap:12px}.page-header-left[data-v-f53e6684]{display:flex;align-items:center;gap:14px}.page-icon-wrap[data-v-f53e6684]{width:44px;height:44px;border-radius:12px;background:#0ea5e9;display:flex;align-items:center;justify-content:center;flex-shrink:0}.page-icon-wrap i[data-v-f53e6684]{color:#fff;font-size:18px}.page-title[data-v-f53e6684]{font-size:18px;font-weight:800;color:#1e293b;line-height:1.2;margin:0}.page-subtitle[data-v-f53e6684]{font-size:12px;color:#64748b;margin:2px 0 0}.card[data-v-f53e6684]{background:#fff;border:1px solid #e2e8f0;border-radius:14px;overflow:hidden}.card-toolbar[data-v-f53e6684]{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:14px 16px;border-bottom:1px solid #e2e8f0;flex-wrap:wrap}.toolbar-left[data-v-f53e6684]{display:flex;align-items:center;gap:10px;flex-wrap:wrap;flex:1}.toolbar-right[data-v-f53e6684]{display:flex;align-items:center;gap:8px;flex-shrink:0}.search-box[data-v-f53e6684]{position:relative;min-width:200px;max-width:340px;flex:1}.search-icon[data-v-f53e6684]{position:absolute;left:11px;top:50%;transform:translateY(-50%);color:#64748b;font-size:13px;pointer-events:none}.search-input[data-v-f53e6684]{width:100%;padding:8px 32px 8px 34px;border:1.5px solid #e2e8f0;border-radius:8px;font-size:12.5px;font-family:inherit;font-weight:600;background:#fff;color:#1e293b;outline:none;transition:all .2s}.search-input[data-v-f53e6684]:focus{border-color:#0ea5e9;box-shadow:0 0 0 3px #0ea5e91f}.search-input[data-v-f53e6684]::placeholder{color:#64748b;font-weight:500}.search-clear[data-v-f53e6684]{position:absolute;right:8px;top:50%;transform:translateY(-50%);background:none;border:none;cursor:pointer;color:#64748b;font-size:12px;padding:3px;border-radius:4px}.search-clear[data-v-f53e6684]:hover{color:#ef4444}.result-chip[data-v-f53e6684]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:20px;font-size:12px;font-weight:600;color:#0ea5e9;white-space:nowrap}.count-chip[data-v-f53e6684]{display:inline-flex;align-items:center;gap:6px;padding:5px 12px;background:#f8fafc;border:1px solid #e2e8f0;border-radius:20px;font-size:12px;font-weight:600;color:#64748b;white-space:nowrap}.table-wrapper[data-v-f53e6684]{overflow-x:auto}.cases-table[data-v-f53e6684]{width:100%;border-collapse:collapse;font-size:12.5px;min-width:1100px}.cases-table thead tr[data-v-f53e6684]{background:#f8fafc;border-bottom:2px solid #e2e8f0}.cases-table th[data-v-f53e6684]{padding:11px 14px;text-align:left;font-size:11px;font-weight:800;color:#64748b;text-transform:uppercase;letter-spacing:.6px;white-space:nowrap}.th-num[data-v-f53e6684]{width:44px;text-align:center}.cases-table tbody tr[data-v-f53e6684]{border-bottom:1px solid #e2e8f0;transition:background .15s}.cases-table tbody tr[data-v-f53e6684]:last-child{border-bottom:none}.data-row[data-v-f53e6684]:hover{background:#f8fafc}.cases-table td[data-v-f53e6684]{padding:11px 14px;color:#1e293b;vertical-align:middle}.td-num[data-v-f53e6684]{text-align:center;font-size:11.5px;font-weight:700;color:#64748b}.badge-code[data-v-f53e6684]{display:inline-flex;align-items:center;gap:5px;padding:3px 9px;background:#1976d214;border:1px solid rgba(25,118,210,.18);border-radius:6px;font-size:11.5px;font-weight:800;color:#0ea5e9;white-space:nowrap}.badge-code i[data-v-f53e6684]{font-size:10px;opacity:.7}.cell-name[data-v-f53e6684]{display:flex;align-items:center;gap:9px}.avatar-circle[data-v-f53e6684]{width:30px;height:30px;border-radius:50%;background:#0ea5e9;color:#fff;font-size:12px;font-weight:800;display:flex;align-items:center;justify-content:center;flex-shrink:0}.name-text[data-v-f53e6684]{font-weight:700;color:#1e293b}.position-text[data-v-f53e6684]{display:flex;align-items:center;gap:5px;font-size:12px;color:#64748b;font-weight:600}.pos-icon[data-v-f53e6684]{font-size:10px;opacity:.6}.location-text[data-v-f53e6684]{display:flex;align-items:center;gap:5px;font-size:12px;color:#64748b;font-weight:600}.loc-icon[data-v-f53e6684]{font-size:10px;color:#ef4444;opacity:.8}.subject-text[data-v-f53e6684]{font-size:12px;font-weight:600;color:#1e293b}.date-cell[data-v-f53e6684]{display:flex;align-items:center;gap:6px;font-size:11.5px;color:#64748b;font-weight:600;white-space:nowrap}.date-icon[data-v-f53e6684]{font-size:11px;opacity:.5}.null-dash[data-v-f53e6684]{color:#cbd5e1;font-size:14px}.action-wrap[data-v-f53e6684]{display:flex;align-items:center;gap:6px}.btn-pdf[data-v-f53e6684]{display:inline-flex;align-items:center;gap:5px;padding:5px 12px;background:#eab3081f;border:1px solid rgba(234,179,8,.35);border-radius:7px;color:#b45309;font-size:11.5px;font-weight:700;cursor:pointer;transition:all .15s;white-space:nowrap}.btn-pdf[data-v-f53e6684]:hover:not(:disabled){background:#eab30838;transform:translateY(-1px)}.btn-pdf[data-v-f53e6684]:disabled{opacity:.6;cursor:not-allowed}.btn-delete[data-v-f53e6684]{display:inline-flex;align-items:center;justify-content:center;width:30px;height:30px;background:#ef444414;border:1px solid rgba(239,68,68,.25);border-radius:7px;color:#ef4444;font-size:12px;cursor:pointer;transition:all .15s;flex-shrink:0}.btn-delete[data-v-f53e6684]:hover:not(:disabled){background:#ef44442e;transform:translateY(-1px)}.btn-delete[data-v-f53e6684]:disabled{opacity:.5;cursor:not-allowed}.state-cell[data-v-f53e6684]{padding:0!important}.state-content[data-v-f53e6684]{display:flex;flex-direction:column;align-items:center;gap:10px;padding:52px 24px;color:#64748b;font-size:13px;font-weight:600}.empty-icon-wrap[data-v-f53e6684]{width:52px;height:52px;border-radius:50%;background:#f8fafc;border:2px dashed #e2e8f0;display:flex;align-items:center;justify-content:center}.empty-icon-wrap i[data-v-f53e6684]{font-size:20px;color:#64748b;opacity:.5}.empty-title[data-v-f53e6684]{font-size:13.5px;font-weight:700;color:#1e293b}.empty-sub[data-v-f53e6684]{font-size:12px;color:#64748b}.spinner[data-v-f53e6684]{width:28px;height:28px;border:3px solid #e2e8f0;border-top-color:#0ea5e9;border-radius:50%;animation:spin-f53e6684 .7s linear infinite}@keyframes spin-f53e6684{to{transform:rotate(360deg)}}.card-footer[data-v-f53e6684]{padding:10px 16px;border-top:1px solid #e2e8f0;background:#f8fafc}.footer-info[data-v-f53e6684]{font-size:12px;color:#64748b;font-weight:600}.fade-enter-active[data-v-f53e6684],.fade-leave-active[data-v-f53e6684]{transition:opacity .2s,transform .2s}.fade-enter-from[data-v-f53e6684],.fade-leave-to[data-v-f53e6684]{opacity:0;transform:scale(.95)}.app-root.dark .page-wrapper[data-v-f53e6684]{background:#0f172a;color:#e5e7eb}.app-root.dark .card[data-v-f53e6684]{background:#1a1a2e;border-color:#374151}.app-root.dark .card-header[data-v-f53e6684]{background:#1a1a2e;border-bottom-color:#374151}.app-root.dark .card-title[data-v-f53e6684]{color:#d1d5db}.app-root.dark .card-sub[data-v-f53e6684]{color:#a0aec0}.app-root.dark table[data-v-f53e6684]{background:#1a1a2e;color:#e5e7eb}.app-root.dark thead[data-v-f53e6684]{background:#0f172a;color:#d1d5db;border-bottom-color:#374151}.app-root.dark tbody tr[data-v-f53e6684]{border-color:#374151}.app-root.dark tbody tr[data-v-f53e6684]:hover{background:#2d3748}.app-root.dark td[data-v-f53e6684]{border-color:#374151;color:#d1d5db}.app-root.dark th[data-v-f53e6684]{color:#d1d5db;border-color:#374151}.app-root.dark .form-control[data-v-f53e6684]{background:#2d3748;border-color:#4b5563;color:#e5e7eb}.app-root.dark .form-control[data-v-f53e6684]::placeholder{color:#9ca3af}.app-root.dark .table-wrap[data-v-f53e6684]{background:#1a1a2e}.app-root.dark .search-input[data-v-f53e6684]{background:#2d3748;border-color:#4b5563;color:#e5e7eb}.app-root.dark .search-input[data-v-f53e6684]::placeholder{color:#9ca3af}.app-root.dark .btn-add[data-v-f53e6684]{background:#3b82f6}.app-root.dark .btn-add[data-v-f53e6684]:hover{background:#2563eb}.app-root.dark button[data-v-f53e6684]{color:#fff}.app-root.dark .empty-icon-wrap[data-v-f53e6684]{background:#2d3748;border-color:#4b5563}.app-root.dark .empty-icon-wrap i[data-v-f53e6684]{color:#6b7280}.app-root.dark .empty-title[data-v-f53e6684]{color:#d1d5db}.app-root.dark .empty-sub[data-v-f53e6684]{color:#a0aec0}.app-root.dark .card-footer[data-v-f53e6684]{background:#2d3748;border-top-color:#374151}.app-root.dark .footer-info[data-v-f53e6684]{color:#a0aec0}.app-root.dark h1[data-v-f53e6684],.app-root.dark h2[data-v-f53e6684],.app-root.dark h3[data-v-f53e6684]{color:#e5e7eb}[data-v-26838c29]{box-sizing:border-box;margin:0;padding:0}.dash-wrap[data-v-26838c29]{padding:20px;background:var(--content-bg);min-height:100vh;font-family:Noto Sans Thai,Noto Sans Lao,sans-serif;font-size:14px;color:var(--tb-text);transition:background .3s,color .3s}.dash-header[data-v-26838c29]{display:flex;align-items:flex-start;justify-content:space-between;flex-wrap:wrap;gap:10px;margin-bottom:18px}.dash-title[data-v-26838c29]{font-size:20px;font-weight:700;color:var(--tb-text);display:flex;align-items:center;gap:10px}.dash-title i[data-v-26838c29]{color:#0ea5e9}.dash-sub[data-v-26838c29]{font-size:13px;color:var(--tb-sub);margin-top:4px}.update-time[data-v-26838c29]{font-size:12px;color:var(--tb-sub);display:flex;align-items:center;gap:6px;margin-top:4px}.loading-box[data-v-26838c29]{display:flex;align-items:center;gap:10px;padding:40px;justify-content:center;color:var(--tb-sub)}.stat-grid[data-v-26838c29]{display:grid;grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-bottom:16px}.stat-card[data-v-26838c29]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:12px;padding:16px 18px;position:relative;overflow:hidden;transition:background .3s,border-color .3s}.stat-accent[data-v-26838c29]{position:absolute;top:0;left:0;width:4px;height:100%;background:var(--accent)}.stat-label[data-v-26838c29]{font-size:12px;color:var(--tb-sub);margin-bottom:8px}.stat-val[data-v-26838c29]{font-size:28px;font-weight:700;color:var(--tb-text);line-height:1}.stat-delta[data-v-26838c29]{font-size:11px;margin-top:6px;color:var(--tb-sub)}.chart-grid-2col[data-v-26838c29]{display:grid;grid-template-columns:2fr 1fr;gap:14px;margin-bottom:14px}.chart-grid-equal[data-v-26838c29]{display:grid;grid-template-columns:1fr 1fr;gap:14px;margin-bottom:14px}.card[data-v-26838c29]{background:var(--tb-bg);border:1px solid var(--tb-border);border-radius:12px;padding:18px;transition:background .3s,border-color .3s}.card-head[data-v-26838c29]{display:flex;align-items:center;justify-content:space-between;margin-bottom:12px}.card-title[data-v-26838c29]{font-size:13px;font-weight:700;color:var(--tb-text)}.card-sub[data-v-26838c29]{font-size:11px;color:var(--tb-sub)}.nav-row[data-v-26838c29]{display:flex;align-items:center;gap:8px}.nav-btn[data-v-26838c29]{background:none;border:1px solid var(--tb-border);border-radius:8px;padding:4px 10px;font-size:12px;color:var(--tb-text);cursor:pointer;transition:background .15s}.nav-btn[data-v-26838c29]:hover{background:var(--tb-hover)}.nav-label[data-v-26838c29]{font-size:13px;font-weight:700;color:var(--tb-text);min-width:90px;text-align:center}.chart-note[data-v-26838c29]{font-size:10px;color:var(--tb-sub);margin-top:8px;text-align:center}.donut-legend[data-v-26838c29]{margin-top:12px}.donut-leg-row[data-v-26838c29]{display:flex;align-items:center;gap:8px;margin-bottom:6px;font-size:12px}.leg-dot[data-v-26838c29]{width:10px;height:10px;border-radius:50%;flex-shrink:0}.donut-leg-label[data-v-26838c29]{flex:1;color:var(--tb-sub)}.donut-leg-val[data-v-26838c29]{font-weight:700;color:var(--tb-text)}.table-wrap[data-v-26838c29]{overflow-x:auto}.scrollable-table[data-v-26838c29]{overflow-y:auto}.scroll-hint[data-v-26838c29]{text-align:center;font-size:10px;color:var(--tb-sub);margin-top:6px}table[data-v-26838c29]{width:100%;border-collapse:collapse;font-size:12px;background:transparent}th[data-v-26838c29]{text-align:left;padding:8px 10px;font-size:11px;font-weight:700;color:var(--tb-sub);border-bottom:1px solid var(--tb-border);position:sticky;top:0;background:var(--tb-bg);z-index:1}td[data-v-26838c29]{padding:8px 10px;border-bottom:1px solid var(--tb-border);color:var(--tb-text);vertical-align:middle}tr:last-child td[data-v-26838c29]{border-bottom:none}.data-row:hover td[data-v-26838c29]{background:var(--tb-hover)}.row-expanded td[data-v-26838c29]{background:var(--sb-hover)!important}.td-code[data-v-26838c29]{font-size:11px;color:var(--tb-sub)}.td-name[data-v-26838c29]{font-weight:700;color:var(--tb-text)}.td-dept[data-v-26838c29]{font-size:11px;color:var(--tb-sub)}.cnt-badge[data-v-26838c29]{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:12px;font-weight:700;cursor:pointer;transition:opacity .15s;-webkit-user-select:none;user-select:none}.cnt-badge[data-v-26838c29]:hover{opacity:.75}.expand-row td[data-v-26838c29]{padding:0!important;background:var(--tb-bg)!important;border-bottom:2px solid #0ea5e9!important}.expand-box[data-v-26838c29]{padding:10px 12px 12px}.expand-head[data-v-26838c29]{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.expand-title[data-v-26838c29]{font-size:12px;color:var(--tb-text);display:flex;align-items:center;gap:6px;flex-wrap:wrap}.expand-title i[data-v-26838c29]{color:#0ea5e9}.pill-verbal[data-v-26838c29]{display:inline-block;padding:1px 8px;border-radius:20px;background:#e1f5ee;color:#0f6e56;font-size:11px;font-weight:700}.pill-disc[data-v-26838c29]{display:inline-block;padding:1px 8px;border-radius:20px;background:#e6f1fb;color:#185fa5;font-size:11px;font-weight:700}.close-expand-btn[data-v-26838c29]{background:none;border:none;font-size:16px;cursor:pointer;color:var(--tb-sub);padding:0 4px;line-height:1}.close-expand-btn[data-v-26838c29]:hover{color:#ef4444}.inner-table[data-v-26838c29]{width:100%;border-collapse:collapse;font-size:11.5px;background:var(--tb-bg);border-radius:8px;overflow:hidden;border:1px solid var(--tb-border)}.inner-table th[data-v-26838c29]{font-size:10px;padding:6px 10px;background:var(--tb-hover);color:var(--tb-sub);font-weight:700;border-bottom:1px solid var(--tb-border);position:static}.inner-table td[data-v-26838c29]{padding:7px 10px;border-bottom:1px solid var(--tb-border);vertical-align:middle;color:var(--tb-text)}.inner-row:last-child td[data-v-26838c29]{border-bottom:none}.inner-row:hover td[data-v-26838c29]{background:var(--tb-hover)}.inner-row td.td-code[data-v-26838c29]{color:var(--tb-sub)}.badge[data-v-26838c29],.src-pill[data-v-26838c29]{padding:2px 9px;border-radius:20px;font-size:11px;font-weight:600}.btn-pdf[data-v-26838c29]{border:none;border-radius:8px;padding:4px 10px;font-size:11px;cursor:pointer;background:#3b82f6;color:#fff;display:inline-flex;align-items:center;gap:4px;font-family:inherit;transition:background .15s;white-space:nowrap}.btn-pdf[data-v-26838c29]:hover:not(:disabled){background:#2563eb}.btn-pdf[data-v-26838c29]:disabled{opacity:.5;cursor:not-allowed}@media(max-width:1024px){.chart-grid-2col[data-v-26838c29],.chart-grid-equal[data-v-26838c29]{grid-template-columns:1fr}}@media(max-width:640px){.stat-grid[data-v-26838c29]{grid-template-columns:repeat(2,1fr)}.dash-wrap[data-v-26838c29]{padding:12px}}.app-root.dark .dash-wrap[data-v-26838c29]{background:#0f172a;color:#e5e7eb}.app-root.dark .stat-card[data-v-26838c29]{background:#1a1a2e;border-color:#374151}.app-root.dark .stat-val[data-v-26838c29]{color:#fff}.app-root.dark .stat-label[data-v-26838c29]{color:#94a3b8}.app-root.dark .card[data-v-26838c29]{background:#1a1a2e;border-color:#374151}.app-root.dark .card-title[data-v-26838c29]{color:#e2e8f0}.app-root.dark .card-sub[data-v-26838c29]{color:#94a3b8}.app-root.dark .nav-btn[data-v-26838c29]{border-color:#374151;color:#94a3b8}.app-root.dark .nav-label[data-v-26838c29]{color:#fff}.app-root.dark table th[data-v-26838c29]{background:#1a1a2e;border-color:#374151;color:#94a3b8}.app-root.dark table td[data-v-26838c29]{border-color:#374151;color:#cbd5e1}.app-root.dark .td-name[data-v-26838c29]{color:#fff}.app-root.dark .td-code[data-v-26838c29],.app-root.dark .td-dept[data-v-26838c29]{color:#64748b}.app-root.dark .data-row:hover td[data-v-26838c29]{background:#1e293b}.app-root.dark .inner-table[data-v-26838c29]{background:#0f172a;border-color:#374151}.app-root.dark .inner-table th[data-v-26838c29]{background:#1e293b;border-color:#374151;color:#94a3b8}.app-root.dark .inner-table td[data-v-26838c29]{border-color:#374151;color:#cbd5e1}.app-root.dark .inner-row:hover td[data-v-26838c29]{background:#1e293b}.app-root.dark .expand-box[data-v-26838c29]{background:#1a1a2e}.app-root.dark .expand-title[data-v-26838c29]{color:#e2e8f0}.app-root.dark .close-expand-btn[data-v-26838c29]{color:#64748b}.app-root.dark .close-expand-btn[data-v-26838c29]:hover{color:#f87171}.app-root.dark .pill-verbal[data-v-26838c29]{background:#10b98126;color:#34d399}.app-root.dark .pill-disc[data-v-26838c29]{background:#3b82f626;color:#60a5fa}.app-root.dark .donut-leg-val[data-v-26838c29],.app-root.dark .dash-title[data-v-26838c29]{color:#fff}.app-root.dark .dash-sub[data-v-26838c29]{color:#94a3b8}.app-root.dark .update-time[data-v-26838c29]{color:#64748b}
