@import"https://fonts.googleapis.com/css2?family=Inter:opsz,wght@14..32,300;14..32,400;14..32,500;14..32,600&family=JetBrains+Mono:wght@400;500;600&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-base: #0a0f1a;--bg-card: #111826;--bg-elevated: #161f2e;--bg-hover: #1a2438;--bg-input: #0e1520;--glass-bg: rgba(17, 24, 38, .82);--glass-border: rgba(255, 255, 255, .055);--glass-blur: blur(14px);--border: #1e2d42;--border-hover: #2a3d57;--border-focus: #3b82f6;--text-primary: #e2ecf8;--text-secondary: #7290ae;--text-muted: #3d4f66;--accent: #3b82f6;--accent-hover: #2563eb;--accent-dim: rgba(59, 130, 246, .1);--accent-glow: rgba(59, 130, 246, .25);--accent-gradient: linear-gradient(135deg, #1d4ed8 0%, #3b82f6 100%);--success: #22c55e;--success-dim: rgba(34, 197, 94, .1);--warning: #f59e0b;--warning-dim: rgba(245, 158, 11, .1);--danger: #ef4444;--danger-dim: rgba(239, 68, 68, .1);--recovery: #f97316;--recovery-dim: rgba(249, 115, 22, .1);--r-sm: 5px;--r-md: 8px;--r-lg: 12px;--r-xl: 16px;--shadow-sm: 0 1px 3px rgba(0,0,0,.5);--shadow-md: 0 4px 20px rgba(0,0,0,.55);--shadow-lg: 0 12px 40px rgba(0,0,0,.65);--shadow-xl: 0 24px 64px rgba(0,0,0,.75);--shadow-card: 0 1px 1px rgba(0,0,0,.5), inset 0 1px 0 rgba(255,255,255,.045);--shadow-btn: 0 2px 8px rgba(59, 130, 246, .45);--shadow-glow: 0 0 24px rgba(59, 130, 246, .18);--t-fast: .12s ease;--t-base: .18s ease;--t-slow: .28s ease;--node-root: #fca5a5;--node-donggoi: #c4b5fd;--node-cat: #7dd3fc;--node-in: #6ee7b7;--node-say: #fde68a;--node-rw: #bbf7d0;--node-ghep: #bfdbfe;--node-nvl: #cbd5e1;--node-thuhoi: #fdba74;--node-searched: #fef08a}html,body{height:100%}body{font-family:Inter,-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}#root{height:100%;display:flex;flex-direction:column}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#1e2d42;border-radius:99px;transition:background var(--t-base)}::-webkit-scrollbar-thumb:hover{background:#2a3d57}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 12px #3b82f61f}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:invert(.7);cursor:pointer;opacity:.7}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:500;box-shadow:var(--shadow-btn);border:1px solid rgba(59,130,246,.3)}.btn-primary:hover:not(:disabled){background:linear-gradient(135deg,#1a43c8,#2563eb);box-shadow:0 4px 16px #3b82f68c;transform:translateY(-1px)}.btn-primary:active:not(:disabled){transform:translateY(0);box-shadow:var(--shadow-btn)}.btn-primary:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none}.btn-secondary{background:var(--bg-elevated);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);box-shadow:0 0 0 1px #3b82f61a}.btn-secondary:disabled{opacity:.4;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(239,68,68,.35)}.btn-danger:hover{background:var(--danger-dim);border-color:var(--danger);box-shadow:0 0 12px #ef444426}.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),inset 0 1px #ffffff0d}.badge{display:inline-flex;align-items:center;padding:2px 9px;border-radius:99px;font-size:11px;font-weight:500;letter-spacing:.02em}.role-admin{background:#ef44441f;color:#fca5a5;border:1px solid rgba(239,68,68,.25)}.role-manager{background:#f59e0b1f;color:#fde68a;border:1px solid rgba(245,158,11,.25)}.role-operator{background:#22c55e1f;color:#86efac;border:1px solid rgba(34,197,94,.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}.tab-item:hover{color:var(--text-primary)}.tab-item.active{color:var(--accent);border-bottom-color:var(--accent);font-weight:500}.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:#ffffff03}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;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(--glass-border);border-radius:var(--r-xl);padding:28px 32px;box-shadow:var(--shadow-xl),inset 0 1px #ffffff0d;animation:slideUp .2s ease}
