@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&family=JetBrains+Mono:wght@400;500;700&display=swap";:root{--color-bg-deep: #070b14;--color-bg-primary: #0c1220;--color-bg-card: rgba(15, 23, 42, .6);--color-bg-card-hover: rgba(22, 33, 55, .7);--color-bg-elevated: rgba(30, 41, 59, .5);--color-border: rgba(148, 163, 184, .08);--color-border-glow: rgba(148, 163, 184, .15);--color-text-primary: #f1f5f9;--color-text-secondary: #94a3b8;--color-text-muted: #475569;--color-accent: #3b82f6;--color-accent-hover: #2563eb;--color-success: #10b981;--color-danger: #ef4444;--color-warning: #f59e0b;--glass-blur: 20px;--radius-sm: 10px;--radius-md: 14px;--radius-lg: 20px;--transition: .3s cubic-bezier(.4, 0, .2, 1)}*{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:Inter,system-ui,-apple-system,sans-serif;background:var(--color-bg-deep);color:var(--color-text-primary);min-height:100vh;line-height:1.6;overflow-x:hidden}body:before{content:"";position:fixed;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(ellipse at 20% 20%,rgba(59,130,246,.04) 0%,transparent 50%),radial-gradient(ellipse at 80% 80%,rgba(16,185,129,.03) 0%,transparent 50%),radial-gradient(ellipse at 50% 50%,rgba(139,92,246,.02) 0%,transparent 50%);pointer-events:none;z-index:0;animation:ambient-drift 30s ease-in-out infinite alternate}@keyframes ambient-drift{0%{transform:translate(0) rotate(0)}to{transform:translate(-2%,2%) rotate(3deg)}}#root{min-height:100vh;display:flex;flex-direction:column;position:relative;z-index:1}::-webkit-scrollbar{width:3px;height:3px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#64748b4d;border-radius:10px}.app-layout{display:flex;min-height:100vh}.sidebar{width:240px;background:linear-gradient(180deg,#070b14f2,#0c1220fa);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border-right:1px solid var(--color-border);padding:24px 0;display:flex;flex-direction:column;position:fixed;left:0;top:0;bottom:0;z-index:100}.sidebar-logo{padding:0 24px 24px;border-bottom:1px solid var(--color-border);margin-bottom:16px}.sidebar-logo h1{font-size:15px;font-weight:800;letter-spacing:.05em;text-transform:uppercase;color:#fff}.sidebar-logo h1 .admin-badge{font-size:10px;font-weight:700;margin-left:8px;padding:2px 8px;border-radius:100px;background:#3b82f61f;border:1px solid rgba(59,130,246,.2);color:var(--color-accent);vertical-align:middle}.sidebar-logo span{display:block;font-size:11px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1.5px;margin-top:4px}.sidebar-nav{flex:1;padding:0 12px}.sidebar-nav a{display:flex;align-items:center;gap:12px;padding:11px 14px;border-radius:var(--radius-sm);color:var(--color-text-muted);text-decoration:none;font-size:13px;font-weight:600;transition:all var(--transition);margin-bottom:2px;letter-spacing:.01em}.sidebar-nav a:hover{background:#3341554d;color:var(--color-text-secondary)}.sidebar-nav a.active{background:#3b82f61a;color:var(--color-accent);border:1px solid rgba(59,130,246,.12)}.sidebar-nav a .nav-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-nav a .nav-icon svg{width:18px;height:18px}.main-content{margin-left:240px;flex:1;padding:32px;min-height:100vh}.page-header{margin-bottom:28px}.page-header h2{font-size:20px;font-weight:800;letter-spacing:-.02em;color:#fff;text-transform:uppercase}.page-header p{color:var(--color-text-muted);font-size:13px;margin-top:4px;letter-spacing:.02em}.card{background:var(--color-bg-card);backdrop-filter:blur(var(--glass-blur));-webkit-backdrop-filter:blur(var(--glass-blur));border:1px solid var(--color-border);border-radius:var(--radius-md);padding:20px;transition:all var(--transition);position:relative;overflow:hidden}.card:before{content:"";position:absolute;top:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,rgba(255,255,255,.06),transparent)}.card:hover{background:var(--color-bg-card-hover);border-color:var(--color-border-glow)}.card-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(220px,1fr));gap:16px;margin-bottom:24px}.card-title{font-size:11px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-muted);margin-bottom:10px}.card-value{font-size:28px;font-weight:800;letter-spacing:-.03em;font-family:JetBrains Mono,monospace}.card-subtitle{font-size:11px;color:var(--color-text-muted);margin-top:4px;letter-spacing:.02em}.status-dot{width:8px;height:8px;border-radius:50%;display:inline-block;margin-right:6px}.status-dot.online{background:var(--color-success);box-shadow:0 0 10px #10b98180;animation:pulse-glow 2s ease-in-out infinite}.status-dot.waiting_login{background:var(--color-warning);box-shadow:0 0 10px #f59e0b80;animation:pulse-glow 1.5s ease-in-out infinite}.status-dot.offline{background:var(--color-danger);box-shadow:0 0 10px #ef444480}@keyframes pulse-glow{0%,to{opacity:1}50%{opacity:.4}}.table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--color-border);background:var(--color-bg-card);-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));margin-bottom:24px}table{width:100%;border-collapse:collapse;font-size:13px}th{text-align:left;padding:14px 16px;background:#0f172acc;color:var(--color-text-muted);font-weight:700;font-size:10px;text-transform:uppercase;letter-spacing:.1em;border-bottom:1px solid var(--color-border);white-space:nowrap}td{padding:12px 16px;border-bottom:1px solid var(--color-border);color:var(--color-text-secondary)}tr:hover td{background:#1e293b4d}tr:last-child td{border-bottom:none}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:100px;font-size:10px;font-weight:700;letter-spacing:.06em;text-transform:uppercase}.badge-success{background:#10b9811a;color:var(--color-success);border:1px solid rgba(16,185,129,.15)}.badge-warning{background:#f59e0b1a;color:var(--color-warning);border:1px solid rgba(245,158,11,.15)}.badge-danger{background:#ef44441a;color:var(--color-danger);border:1px solid rgba(239,68,68,.15)}.badge-info{background:#3b82f61a;color:var(--color-accent);border:1px solid rgba(59,130,246,.15)}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 20px;border-radius:var(--radius-sm);font-weight:600;font-size:12px;cursor:pointer;border:none;transition:all var(--transition);position:relative;letter-spacing:.02em;text-transform:uppercase}.btn:active{transform:scale(.96)}.btn:disabled{opacity:.4;cursor:not-allowed;transform:none}.btn-primary{background:linear-gradient(135deg,#3b82f6,#1d4ed8);color:#fff;box-shadow:0 4px 15px #3b82f640,inset 0 1px #ffffff1a}.btn-primary:hover:not(:disabled){box-shadow:0 6px 25px #3b82f659,inset 0 1px #ffffff26;transform:translateY(-1px)}.btn-ghost{background:#1e293b80;color:var(--color-text-secondary);border:1px solid var(--color-border-glow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-ghost:hover:not(:disabled){background:#33415580;color:var(--color-text-primary);border-color:#94a3b840}.btn-sm{padding:6px 12px;font-size:10px}.btn-danger{background:linear-gradient(135deg,#ef4444,#b91c1c);color:#fff;box-shadow:0 4px 15px #ef444440}.btn-danger:hover:not(:disabled){box-shadow:0 6px 25px #ef444459;transform:translateY(-1px)}.form-group{margin-bottom:16px}.form-label{display:block;font-size:10px;font-weight:700;color:var(--color-text-muted);margin-bottom:6px;text-transform:uppercase;letter-spacing:.1em}.form-input,.form-select{width:100%;padding:10px 14px;background:#0f172a99;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1px solid var(--color-border-glow);border-radius:var(--radius-sm);color:var(--color-text-primary);font-size:13px;font-family:inherit;transition:all var(--transition);outline:none}.form-input:focus,.form-select:focus{border-color:#3b82f680;box-shadow:0 0 0 3px #3b82f61a,0 0 20px #3b82f60d}.form-input::placeholder{color:var(--color-text-muted)}.form-select option{background:#0c1220;color:var(--color-text-primary)}.filter-bar{display:flex;gap:12px;margin-bottom:20px;flex-wrap:wrap;align-items:flex-end}.filter-bar .form-group{margin-bottom:0}.log-viewer{background:#070b14cc;-webkit-backdrop-filter:blur(var(--glass-blur));backdrop-filter:blur(var(--glass-blur));border:1px solid var(--color-border);border-radius:var(--radius-md);padding:16px;max-height:600px;overflow-y:auto;font-family:JetBrains Mono,monospace;font-size:12px;line-height:1.8}.log-entry{padding:2px 0;border-bottom:1px solid rgba(255,255,255,.02)}.log-entry .log-time{color:var(--color-text-muted);margin-right:8px}.log-entry .log-level{font-weight:700;margin-right:8px;padding:1px 6px;border-radius:3px;font-size:10px;letter-spacing:.05em}.log-entry .log-level.INFO{background:#3b82f61f;color:var(--color-accent)}.log-entry .log-level.WARN{background:#f59e0b1f;color:var(--color-warning)}.log-entry .log-level.ERROR{background:#ef44441f;color:var(--color-danger)}.log-entry .log-bot{color:var(--color-accent);margin-right:8px;font-weight:600}.bot-card{padding:24px;position:relative;overflow:hidden}.bot-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;border-radius:2px 2px 0 0}.bot-card.online:before{background:linear-gradient(90deg,transparent,var(--color-success),transparent)}.bot-card.waiting_login:before{background:linear-gradient(90deg,transparent,var(--color-warning),transparent)}.bot-card.offline:before{background:linear-gradient(90deg,transparent,var(--color-danger),transparent)}.bot-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:16px}.bot-card-name{font-size:14px;font-weight:800;text-transform:uppercase;letter-spacing:.02em}.bot-card-port{font-size:11px;color:var(--color-text-muted);font-family:JetBrains Mono,monospace}.bot-card-stats{display:grid;grid-template-columns:1fr 1fr;gap:12px}.bot-stat-label{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.08em;font-weight:700}.bot-stat-value{font-size:20px;font-weight:800;font-family:JetBrains Mono,monospace}.loading{display:flex;align-items:center;justify-content:center;padding:48px;color:var(--color-text-muted);gap:12px}.spinner{width:20px;height:20px;border:2px solid transparent;border-top-color:var(--color-accent);border-right-color:#3b82f64d;border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.empty-state{text-align:center;padding:48px;color:var(--color-text-muted)}.empty-state h3{font-size:14px;margin-bottom:6px;color:var(--color-text-secondary);font-weight:700;text-transform:uppercase;letter-spacing:.05em}.empty-state p{font-size:12px}.section{margin-bottom:24px}.section-title{font-size:12px;font-weight:700;margin-bottom:16px;color:var(--color-text-secondary);display:flex;align-items:center;gap:8px;text-transform:uppercase;letter-spacing:.08em}.section-title svg{width:16px;height:16px;color:var(--color-accent)}@keyframes fade-in{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:fade-in .4s ease-out both}.animate-slide-up{animation:slide-up .4s ease-out both}.stagger-children>*{animation:fade-in .4s ease-out both}.stagger-children>*:nth-child(1){animation-delay:0s}.stagger-children>*:nth-child(2){animation-delay:.05s}.stagger-children>*:nth-child(3){animation-delay:.05s}.stagger-children>*:nth-child(4){animation-delay:.1s}@media(max-width:768px){.sidebar{width:60px;padding:16px 0}.sidebar-logo h1 span,.sidebar-logo span,.sidebar-nav a span:not(.nav-icon){display:none}.sidebar-nav a{justify-content:center;padding:12px}.main-content{margin-left:60px;padding:16px}.card-grid{grid-template-columns:1fr}.filter-bar{flex-direction:column}}.zalo-connect-grid{display:grid;grid-template-columns:1fr 1.5fr;gap:1.5rem}@media(max-width:900px){.zalo-connect-grid{grid-template-columns:1fr}}.zalo-status-card .card-header,.zalo-qr-card .card-header{padding-bottom:16px;border-bottom:1px solid var(--color-border);margin-bottom:0}.zalo-status-card .card-header h3,.zalo-qr-card .card-header h3{font-size:12px;font-weight:700;text-transform:uppercase;letter-spacing:.08em;color:var(--color-text-secondary)}.zalo-state-icon{font-size:3rem;margin-bottom:.75rem}.zalo-state-label{font-size:16px;font-weight:800;text-transform:uppercase;letter-spacing:.05em}.btn-secondary{background:#1e293b80;color:var(--color-text-secondary);border:1px solid var(--color-border-glow);-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px)}.btn-secondary:hover:not(:disabled){background:#33415580;color:var(--color-text-primary);border-color:#94a3b840}.zalo-qr-wrapper{animation:fade-in .4s ease-out}.zalo-qr-image{max-width:280px;width:100%;border-radius:var(--radius-md);border:2px solid var(--color-accent);box-shadow:0 0 30px #3b82f633;margin-bottom:1rem}.zalo-qr-hint{font-size:14px;font-weight:600;color:var(--color-text-primary);margin-bottom:.25rem}.zalo-qr-sub{font-size:12px;color:var(--color-text-muted)}.zalo-connected p,.zalo-offline p,.zalo-starting p{color:var(--color-text-secondary);font-size:14px;font-weight:600}.zalo-offline code{display:inline-block;margin-top:.5rem;padding:6px 14px;background:#0f172acc;border:1px solid var(--color-border-glow);border-radius:6px;font-family:JetBrains Mono,monospace;font-size:12px;color:var(--color-accent)}.zalo-spinner{width:40px;height:40px;border:3px solid transparent;border-top-color:var(--color-accent);border-right-color:#3b82f64d;border-radius:50%;animation:spin .8s linear infinite;margin:0 auto 1rem}.zalo-instructions{padding-left:1.5rem;color:var(--color-text-secondary);font-size:13px;line-height:2}.zalo-instructions code{padding:2px 8px;background:#0f172acc;border:1px solid var(--color-border);border-radius:4px;font-family:JetBrains Mono,monospace;font-size:11px;color:var(--color-accent)}.page-subtitle{color:var(--color-text-muted);font-size:13px;margin-top:4px}
