@import"https://fonts.googleapis.com/css2?family=Chakra+Petch:ital,wght@0,300;0,400;0,500;0,600;0,700;1,400&family=JetBrains+Mono:wght@400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #F5F0E8;--bg-card: #FFFFFF;--bg-elevated: #FDF8F2;--bg-hover: #FFF3DC;--bg-input: #FFFFFF;--glass-bg: rgba(255, 250, 245, .92);--glass-border: rgba(0, 0, 0, .07);--glass-blur: blur(14px);--border: #E0D6C6;--border-hover: #CCC0A8;--border-focus: #CC8800;--text-primary: #111827;--text-secondary: #6B5B4E;--text-muted: #A8998A;--accent: #CC8800;--accent-hover: #B07700;--accent-dim: rgba(204, 136, 0, .1);--accent-glow: rgba(204, 136, 0, .22);--accent-gradient: linear-gradient(135deg, #C55221 0%, #CC8800 100%);--success: #16A34A;--success-dim: rgba(22, 163, 74, .1);--warning: #D97706;--warning-dim: rgba(217, 119, 6, .1);--danger: #DC2626;--danger-dim: rgba(220, 38, 38, .1);--recovery: #C55221;--recovery-dim: rgba(197, 82, 33, .1);--r-sm: 4px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--shadow-sm: 0 1px 2px rgba(0,0,0,.06);--shadow-md: 0 4px 16px rgba(0,0,0,.08);--shadow-lg: 0 12px 32px rgba(0,0,0,.1);--shadow-xl: 0 24px 48px rgba(0,0,0,.12);--shadow-card: 0 1px 3px rgba(0,0,0,.06), 0 1px 2px rgba(0,0,0,.04);--shadow-btn: 0 2px 8px rgba(204,136,0,.3);--shadow-glow: 0 0 20px rgba(204,136,0,.18);--t-fast: .12s ease;--t-base: .18s ease;--t-slow: .28s ease;--node-root: #92400E;--node-donggoi: #164E63;--node-cat: #1E3A8A;--node-in: #14532D;--node-say: #7C2D12;--node-rw: #365314;--node-ghep: #1E1B4B;--node-nvl: #334155;--node-thuhoi: #7C2D12;--node-searched: #713F12}html,body{height:100%}body{font-family:Chakra Petch,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg-base);color:var(--text-primary);font-size:14px;line-height:1.6;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;text-rendering:optimizeLegibility}#root{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#d4c8b4;border-radius:99px;transition:background var(--t-base)}::-webkit-scrollbar-thumb:hover{background:#c80}input,select,textarea{background:var(--bg-input);border:1px solid var(--border);border-radius:var(--r-md);color:var(--text-primary);padding:8px 11px;font-size:13px;font-family:inherit;outline:none;transition:border-color var(--t-base),box-shadow var(--t-base)}input:hover:not(:focus),select:hover:not(:focus){border-color:var(--border-hover)}input:focus,select:focus,textarea:focus{border-color:var(--border-focus);box-shadow:0 0 0 3px var(--accent-glow),0 0 8px #cc88001a}input::placeholder{color:var(--text-muted)}input[type=number]{-moz-appearance:textfield}input[type=number]::-webkit-outer-spin-button,input[type=number]::-webkit-inner-spin-button{-webkit-appearance:none}input[type=date]::-webkit-calendar-picker-indicator{filter:none;cursor:pointer;opacity:.6}input[type=date]::-webkit-calendar-picker-indicator:hover{opacity:1}select option{background:var(--bg-card)}button{cursor:pointer;font-family:inherit;font-size:13px;border:none;border-radius:var(--r-md);padding:8px 14px;transition:all var(--t-base);outline:none;white-space:nowrap;display:inline-flex;align-items:center;gap:6px}.btn-primary{background:var(--accent-gradient);color:#fff;font-weight:600;box-shadow:var(--shadow-btn);border:1px solid rgba(197,82,33,.2);letter-spacing:.02em}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#a8401a,#b07700);box-shadow:0 4px 16px #c806;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-btn)}.btn-primary:disabled{opacity:.45;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-card);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--accent);color:var(--accent);background:var(--accent-dim)}.btn-secondary:disabled{opacity:.45;cursor:not-allowed}.btn-ghost{background:transparent;color:var(--text-secondary);border:1px solid transparent}.btn-ghost:hover{background:var(--bg-hover);border-color:var(--border);color:var(--text-primary)}.btn-danger{background:transparent;color:var(--danger);border:1px solid rgba(220,38,38,.3)}.btn-danger:hover{background:var(--danger-dim);border-color:var(--danger);box-shadow:0 0 12px #dc26261f}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-lg);padding:16px;box-shadow:var(--shadow-card);transition:box-shadow var(--t-base),border-color var(--t-base)}.card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.glass{background:var(--glass-bg);backdrop-filter:var(--glass-blur);-webkit-backdrop-filter:var(--glass-blur);border:1px solid var(--glass-border);box-shadow:var(--shadow-md)}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:600;letter-spacing:.03em}.role-admin{background:#dc262614;color:#b91c1c;border:1px solid rgba(220,38,38,.2)}.role-manager{background:#cc88001a;color:#92400e;border:1px solid rgba(204,136,0,.25)}.role-operator{background:#16a34a1a;color:#15803d;border:1px solid rgba(22,163,74,.25)}@keyframes spin{to{transform:rotate(360deg)}}.spinner{width:16px;height:16px;border:2px solid var(--border);border-top-color:var(--accent);border-radius:50%;animation:spin .65s linear infinite;display:inline-block;flex-shrink:0}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@keyframes pulseGlow{0%,to{box-shadow:0 0 0 0 var(--accent-glow)}50%{box-shadow:0 0 16px 4px var(--accent-glow)}}.animate-fade-in{animation:fadeIn var(--t-slow) ease both}.animate-slide-up{animation:slideUp var(--t-slow) ease both}.tab-bar{display:flex;gap:2px;padding:0 16px;background:var(--bg-card);border-bottom:1px solid var(--border)}.tab-item{padding:9px 14px;font-size:12px;background:none;border:none;border-bottom:2px solid transparent;border-radius:0;color:var(--text-secondary);font-weight:400;transition:color var(--t-base);cursor:pointer;letter-spacing:.02em}.tab-item:hover{color:var(--text-primary)}.tab-item.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:600}.divider{height:1px;background:linear-gradient(90deg,transparent,var(--border),transparent);margin:12px 0}button,a,input,select,textarea,[role=button]{touch-action:manipulation;-webkit-tap-highlight-color:transparent}input,select,textarea{font-size:max(16px,1em)}@media(max-width:1023px){button{min-height:40px}.ctrl-desktop{display:none!important}input[type=text],input[type=search]{font-size:16px;padding:10px 12px}}.mono{font-family:JetBrains Mono,monospace}.w-full{width:100%}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:8px}.gap-3{gap:12px}.gap-4{gap:16px}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.data-table{width:100%;border-collapse:collapse;font-size:12px}.data-table tbody tr{transition:background var(--t-fast)}.data-table tbody tr:hover{background:var(--bg-hover)!important}.data-table tbody tr:nth-child(2n){background:#00000005}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#11182773;display:flex;align-items:center;justify-content:center;z-index:1000;backdrop-filter:blur(6px);-webkit-backdrop-filter:blur(6px);animation:fadeIn .15s ease}.modal-card{background:var(--bg-card);border:1px solid var(--border);border-radius:var(--r-xl);padding:28px 32px;box-shadow:var(--shadow-xl);animation:slideUp .2s ease}
