:root{--bg-app: #09090b;--bg-panel: #18181b;--bg-card: #27272a;--bg-card-hover: #3f3f46;--accent-primary: #d4f238;--accent-secondary: #8b5cf6;--accent-tertiary: #ec4899;--accent-success: #10b981;--accent-warning: #f59e0b;--accent-danger: #ef4444;--accent-glow: rgba(212, 242, 56, .2);--text-primary: #f4f4f5;--text-secondary: #a1a1aa;--text-tertiary: #71717a;--border-subtle: rgba(255, 255, 255, .08);--border-hover: rgba(255, 255, 255, .15);--bento-radius: 16px;--bento-gap: 16px;--sidebar-width: 240px;--font-sans: "Inter", system-ui, -apple-system, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", monospace;--shadow-soft: 0 4px 24px rgba(0, 0, 0, .4);--shadow-glow: 0 0 24px rgba(212, 242, 56, .15);--space-1: 4px;--space-2: 8px;--space-3: 12px;--space-4: 16px;--space-5: 20px;--space-6: 24px;--space-8: 32px;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--text-muted: var(--text-tertiary);--border-color: var(--border-subtle);--bg-primary: var(--bg-app);--bg-secondary: var(--bg-card);--bg-tertiary: var(--bg-card-hover);--radius-md: 12px;--radius-lg: 16px;--radius-sm: 8px;--color-green: #22c55e;--color-blue: #3b82f6;--color-amber: #f59e0b;--color-red: #ef4444;--color-purple: #a855f7;--color-muted: #6b7280;--color-lavender: #a78bfa;--color-canvas-bg: #1a1b26;--color-toggle-knob: #fff;--color-check-success: #22c55e}*{box-sizing:border-box;margin:0;padding:0;font-family:var(--font-sans)}body{background-color:var(--bg-app);color:var(--text-primary);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;overflow:hidden}::selection{background:#d4f2384d;color:#fff}#root{height:100vh;width:100vw;max-width:100vw;max-height:100vh;display:flex;overflow:hidden}.page-enter{animation:fade-in-up .4s cubic-bezier(.16,1,.3,1)}@keyframes fade-in-up{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}::-webkit-scrollbar{width:5px;height:5px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#ffffff1a;border-radius:10px;transition:background .2s}::-webkit-scrollbar-thumb:hover{background:#fff3}.app-layout{display:flex;width:100%;height:100%;max-width:100vw;max-height:100vh;padding:var(--bento-gap);gap:var(--bento-gap);background:var(--bg-app);overflow:hidden}.sidebar{width:var(--sidebar-width);min-width:var(--sidebar-width);flex-shrink:0;background:var(--bg-panel);border-radius:var(--bento-radius);display:flex;flex-direction:column;padding:20px 16px;border:1px solid var(--border-subtle);height:100%;overflow:hidden;transition:width .3s ease;box-shadow:var(--shadow-soft)}.sidebar-brand{display:flex;align-items:center;gap:12px;margin-bottom:32px;padding:0 8px}.brand-logo{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:10px;display:flex;align-items:center;justify-content:center;color:#fff;box-shadow:0 4px 12px var(--accent-glow)}.brand-info{display:flex;flex-direction:column;line-height:1.2}.brand-name{font-weight:800;font-size:1.1rem;letter-spacing:-.5px;color:#fff}.brand-subtitle{font-size:.65rem;letter-spacing:1px;color:var(--text-tertiary);font-weight:600;text-transform:uppercase}.sidebar-nav{display:flex;flex-direction:column;gap:6px;flex:1;overflow-y:auto}.nav-section-label{font-size:.7rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:700;margin:16px 0 8px 12px;letter-spacing:.5px}.nav-item{display:flex;align-items:center;gap:12px;padding:10px 12px;border-radius:10px;color:var(--text-secondary);text-decoration:none;font-size:.9rem;font-weight:500;transition:all .2s cubic-bezier(.16,1,.3,1);border-left:3px solid transparent}.nav-item:hover{background:#ffffff0d;color:var(--text-primary)}.nav-item.active{background:linear-gradient(90deg,rgba(212,242,56,.15),transparent);color:var(--text-primary);border-left-color:var(--accent-primary)}.nav-item svg{opacity:.7;transition:opacity .2s}.nav-item.active svg{opacity:1;color:var(--accent-primary);filter:drop-shadow(0 0 8px var(--accent-glow))}.sidebar-footer{margin-top:auto;padding-top:16px;border-top:1px solid var(--border-subtle);display:flex;align-items:center;justify-content:space-between;gap:12px}.user-profile-mini{display:flex;align-items:center;gap:12px;flex:1;overflow:hidden}.user-avatar-placeholder{width:36px;height:36px;background:linear-gradient(135deg,#3f3f46,#27272a);border-radius:10px;display:flex;align-items:center;justify-content:center;font-weight:700;color:#fff;font-size:1rem;border:1px solid var(--border-subtle)}.user-info-mini{display:flex;flex-direction:column;overflow:hidden}.user-name{font-size:.85rem;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-role{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.btn-logout{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:10px;color:var(--text-tertiary);cursor:pointer;transition:all .2s}.btn-logout:hover{background:#ef44441a;color:var(--accent-danger)}.main-content{flex:1;min-width:0;min-height:0;background:var(--bg-panel);border-radius:var(--bento-radius);border:1px solid var(--border-subtle);padding:24px 32px;overflow-y:auto;overflow-x:hidden;display:flex;flex-direction:column;gap:24px;box-shadow:var(--shadow-soft)}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px;gap:16px;flex-wrap:nowrap;min-height:48px}.page-header .flex{flex-shrink:0}.page-title{font-size:1.75rem;font-weight:700;letter-spacing:-.5px;white-space:nowrap;flex-shrink:0;color:var(--text-primary)}.page-subtitle{font-size:var(--font-size-base);color:var(--text-secondary);margin-top:4px}.bento-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:16px;grid-auto-rows:minmax(120px,auto)}.bento-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;display:flex;flex-direction:column;justify-content:space-between;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;overflow:hidden;box-shadow:0 2px 8px #0003}.bento-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.col-span-1{grid-column:span 1}.col-span-2{grid-column:span 2}.col-span-3{grid-column:span 3}.col-span-4{grid-column:span 4}.row-span-2{grid-row:span 2}.stat-icon{width:40px;height:40px;border-radius:10px;background:#d4f2381a;display:flex;align-items:center;justify-content:center;color:var(--accent-primary);margin-bottom:16px}.stat-value{font-size:2rem;font-weight:800;color:var(--text-primary);line-height:1;margin:8px 0 4px;letter-spacing:-.5px}.stat-label{font-size:.85rem;color:var(--text-secondary);font-weight:500}.stat-trend{font-size:.75rem;margin-top:auto;color:var(--accent-success);font-weight:500;display:flex;align-items:center;gap:4px}.table-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:0;overflow:hidden;box-shadow:0 2px 8px #0003}.table-header-area{padding:20px 24px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.table-container{width:100%;overflow-x:auto;-webkit-overflow-scrolling:touch}.table{width:100%;border-collapse:collapse;min-width:600px}.table th{text-align:left;padding:14px 24px;font-size:.75rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;letter-spacing:.5px;background:#0003;border-bottom:1px solid var(--border-subtle)}.table td{padding:16px 24px;font-size:.875rem;color:var(--text-secondary);border-bottom:1px solid var(--border-subtle);transition:background .2s}.table tr:last-child td{border-bottom:none}.table tr:hover td{background:#ffffff05;color:var(--text-primary)}.status-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:9999px;font-size:.75rem;font-weight:600;text-transform:uppercase;background:#ffffff0d;border:1px solid transparent;letter-spacing:.5px}.status-badge.online,.status-badge.ok{color:var(--accent-success);background:#10b9811a;border-color:#10b98133}.status-badge.offline,.status-badge.error{color:var(--accent-danger);background:#ef44441a;border-color:#ef444433}.status-dot{width:8px;height:8px;border-radius:50%;background:currentColor;box-shadow:0 0 8px currentColor}.btn{display:inline-flex;align-items:center;justify-content:center;gap:8px;padding:10px 18px;border-radius:var(--radius-md);font-size:.875rem;font-weight:600;cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);border:1px solid transparent;outline:none}.btn-primary{background:var(--accent-primary);color:#000;font-weight:600;border:none;box-shadow:0 4px 12px var(--accent-glow)}.btn-primary:hover{filter:brightness(1.1);transform:translateY(-1px);box-shadow:0 6px 16px var(--accent-glow)}.btn-secondary{background:#ffffff0d;border:1px solid var(--border-subtle);color:var(--text-primary)}.btn-secondary:hover{border-color:var(--border-hover);background:#ffffff1a;transform:translateY(-1px)}input,textarea{background:var(--bg-app);border:1px solid var(--border-subtle);padding:12px 16px;border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;width:100%;transition:all .2s;outline:none}input:focus,textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 2px var(--accent-glow)}select{appearance:none;-webkit-appearance:none;-moz-appearance:none;background:var(--bg-app);border:1px solid var(--border-subtle);padding:10px 40px 10px 16px;border-radius:var(--radius-md);color:var(--text-primary);font-size:.875rem;font-weight:500;width:100%;cursor:pointer;transition:all .2s ease;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='16' height='16' viewBox='0 0 24 24' fill='none' stroke='%23a1a1aa' stroke-width='2' stroke-linecap='round' stroke-linejoin='round'%3E%3Cpolyline points='6 9 12 15 18 9'%3E%3C/polyline%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 16px center}select:hover{border-color:var(--border-hover);background:linear-gradient(to bottom,#464655e6,#323241f2)}select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #d4f2381a,0 2px 8px #0003}select option{background:var(--bg-card);color:var(--text-primary);padding:12px}input:focus,textarea:focus{outline:none;border-color:var(--accent-primary)}.flex{display:flex}.items-center{align-items:center}.justify-between{justify-content:space-between}.text-accent{color:var(--accent-primary)}.text-secondary{color:var(--text-secondary)}.card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 8px #0003}.card:hover{border-color:var(--border-hover);box-shadow:0 8px 24px #0000004d;transform:translateY(-2px)}.card-title{font-size:1.125rem;font-weight:700;margin-bottom:20px;color:var(--text-primary);letter-spacing:-.5px}.canvas-container{flex:1;background:var(--bg-app);border-radius:var(--radius-lg);overflow:hidden;border:1px solid var(--border-subtle);position:relative;box-shadow:inset 0 0 24px #0006}.input-group{display:flex;flex-direction:column;gap:8px}.input-label{font-size:.875rem;color:var(--text-secondary);font-weight:600}.react-flow__controls{background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-soft)!important;border-radius:12px!important;overflow:hidden;padding:4px!important}.react-flow__controls-button{border:none!important;background:transparent!important;border-bottom:1px solid var(--border-subtle)!important;color:var(--text-secondary)!important;border-radius:4px!important;margin-bottom:2px!important}.react-flow__controls-button:last-child{border-bottom:none!important;margin-bottom:0!important}.react-flow__minimap{background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;border-radius:12px!important;padding:4px}.page-content{display:flex;flex-direction:column;gap:12px}.canvas-toolbar{position:absolute;top:24px;left:50%;transform:translate(-50%);z-index:100;display:flex;align-items:center;gap:8px;background:#18181bd9;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);padding:8px 16px;border-radius:var(--radius-lg);border:1px solid rgba(255,255,255,.1);box-shadow:0 8px 32px #0006}.toolbar-group{display:flex;align-items:center;gap:6px}.toolbar-divider{width:1px;height:24px;background:#ffffff1a;margin:0 8px}.toolbar-btn{width:36px;height:36px;border-radius:var(--radius-sm);border:none;background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s cubic-bezier(.16,1,.3,1);cursor:pointer}.toolbar-btn:hover{background:#ffffff1a;color:var(--text-primary);transform:translateY(-1px)}.toolbar-btn:disabled{opacity:.4;cursor:not-allowed}.toolbar-btn.active{background:var(--accent-primary);color:#000;box-shadow:0 4px 12px var(--accent-glow)}.toolbar-btn.primary-glow{color:var(--accent-primary)}.toolbar-btn.primary-glow:hover{background:#d4f23826;box-shadow:0 0 20px #d4f23840}.sidebar-toggle-float{position:absolute;top:24px;right:24px;z-index:90;width:48px;height:48px;border-radius:var(--radius-lg);background:var(--bg-card);border:1px solid var(--border-subtle);display:flex;flex-direction:column;align-items:center;justify-content:center;color:var(--text-secondary);cursor:pointer;box-shadow:0 4px 16px #0000004d;transition:all .3s cubic-bezier(.16,1,.3,1)}.sidebar-toggle-float:hover{border-color:var(--accent-primary);color:var(--accent-primary);transform:translateY(-2px);box-shadow:0 8px 24px #0006}.sidebar-toggle-float.hidden{opacity:0;pointer-events:none;transform:translate(20px)}.sidebar-toggle-float .badge{font-size:.75rem;font-weight:700;margin-top:-2px}.floating-sidebar{position:absolute;top:24px;right:24px;bottom:24px;z-index:100;width:320px;transition:transform .4s cubic-bezier(.16,1,.3,1)}.floating-sidebar.collapsed{transform:translate(360px)}.sidebar-glass-panel{width:100%;height:100%;background:#18181bd9;backdrop-filter:blur(24px);-webkit-backdrop-filter:blur(24px);border:1px solid rgba(255,255,255,.1);border-radius:var(--radius-lg);display:flex;flex-direction:column;box-shadow:-12px 0 48px #00000080;overflow:hidden}.floating-header{padding:16px;border-bottom:1px solid rgba(255,255,255,.05);display:flex;justify-content:space-between;align-items:center}.server-count-pill{background:#ffffff1a;padding:2px 8px;border-radius:12px;font-size:.75rem;font-weight:600;color:var(--text-secondary)}.icon-btn-ghost{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:4px;border-radius:4px;transition:all .2s}.icon-btn-ghost:hover{background:#ffffff1a;color:var(--text-primary)}.floating-list{flex:1;overflow-y:auto;padding:12px;display:flex;flex-direction:column;gap:8px}.server-card-item{background:#ffffff08;border:1px solid transparent;border-radius:12px;padding:12px;cursor:pointer;transition:all .2s}.server-card-item:hover{background:#ffffff0f;transform:translate(-2px)}.server-card-item.selected{background:#d4f2380d;border-color:#d4f2384d}.server-card-row{display:flex;align-items:center;justify-content:space-between;gap:8px}.server-card-row.meta{margin-top:6px}.server-name-truncate{font-weight:500;font-size:.9rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.server-flag{font-size:1rem}.status-dot-pulse{width:6px;height:6px;border-radius:50%;background:#4caf50;box-shadow:0 0 8px #4caf50;flex-shrink:0}.status-dot-pulse.offline{background:#ef4444;box-shadow:0 0 8px #ef4444}.status-dot-pulse.maintenance{background:#f59e0b;box-shadow:0 0 8px #f59e0b;animation:pulse-maintenance 2s ease-in-out infinite}@keyframes pulse-maintenance{0%,to{opacity:1}50%{opacity:.3}}.server-ip{font-size:.75rem;color:var(--text-secondary);font-family:monospace}.server-role-badge{font-size:.65rem;text-transform:uppercase;background:#ffffff1a;color:var(--text-secondary);padding:2px 6px;border-radius:4px;font-weight:600}.floating-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text-secondary);opacity:.6}.react-flow__controls{background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-soft)!important;border-radius:12px!important;overflow:hidden;padding:4px!important;left:20px!important;bottom:20px!important}.server-node-header{display:flex;align-items:center;gap:8px;margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-subtle)}.server-node-name{font-weight:700;flex:1;color:var(--text-primary)}.server-node-role{font-size:.7rem;padding:2px 6px;background:#ffffff0d;border-radius:4px;color:var(--text-secondary);text-transform:uppercase}.server-node-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;font-size:.75rem;color:var(--text-secondary)}.server-node-stat{display:flex;align-items:center;gap:4px}.client-node{background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border-radius:50%;width:64px;height:64px;display:flex;align-items:center;justify-content:center;color:#000;font-weight:800;font-size:.875rem;box-shadow:0 0 24px var(--accent-glow);border:2px solid var(--bg-app)}.react-flow__edge-path{stroke-linecap:round}.react-flow__edge.selected .react-flow__edge-path{stroke-width:3px}.edge-controls{z-index:1000}.server-node{background:var(--bg-card);border:2px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;min-width:240px;box-shadow:0 4px 24px #0006;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative}.server-node:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 8px 32px #00000080}.server-node.selected{border-color:var(--accent-primary);box-shadow:0 0 0 3px #d4f23833,0 8px 32px #00000080}.server-node.online{border-color:#10b98180}.connection-count-badge{position:absolute;top:-8px;right:-8px;background:var(--accent-secondary);color:#000;font-size:.65rem;font-weight:700;padding:2px 6px;border-radius:10px;min-width:20px;text-align:center}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;width:100%;flex:1;background:var(--bg-app);padding:24px}.login-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:48px;width:100%;max-width:440px;box-shadow:0 12px 48px #00000080}.login-logo{display:flex;align-items:center;justify-content:center;font-size:1.75rem;font-weight:800;color:var(--text-primary);margin-bottom:12px;letter-spacing:-.5px}.login-logo svg{color:var(--accent-primary);filter:drop-shadow(0 0 12px var(--accent-glow))}.login-subtitle{text-align:center;color:var(--text-secondary);margin-bottom:32px;font-size:.875rem}.passkey-button{width:100%;padding:14px 20px;font-size:1rem;border-radius:var(--radius-md)}:root{--status-offline: var(--accent-danger);--status-online: var(--accent-success)}.toast-container{position:fixed;top:24px;right:24px;z-index:10000;display:flex;flex-direction:column;gap:12px;pointer-events:none}.toast{display:flex;align-items:center;gap:16px;padding:16px 20px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);box-shadow:0 8px 32px #0006;pointer-events:auto;animation:toast-slide-in .3s cubic-bezier(.16,1,.3,1);min-width:320px;max-width:400px}.toast-success{border-left:4px solid var(--accent-success)}.toast-success .toast-icon{color:var(--accent-success)}.toast-error{border-left:4px solid var(--accent-danger)}.toast-error .toast-icon{color:var(--accent-danger)}.toast-info{border-left:4px solid var(--accent-primary)}.toast-info .toast-icon{color:var(--accent-primary)}.toast-icon{flex-shrink:0}.toast-message{flex:1;font-size:.875rem;color:var(--text-primary);font-weight:500}.toast-close{flex-shrink:0;background:none;border:none;color:var(--text-tertiary);cursor:pointer;padding:4px;display:flex;transition:color .2s}.toast-close:hover{color:var(--text-primary)}@keyframes toast-slide-in{0%{transform:translate(100%) scale(.95);opacity:0}to{transform:translate(0) scale(1);opacity:1}}.btn-icon{padding:8px;border-radius:8px;color:var(--text-secondary)}.btn-icon:hover{background:#ffffff0d;color:var(--text-primary)}.btn-danger{background:transparent;border:1px solid rgba(244,67,54,.3);color:#f44336}.btn-danger:hover{background:#f443361a;border-color:#f44336}.btn:disabled{opacity:.5;cursor:not-allowed}.gap-2{gap:8px}.gap-4{gap:16px}.mb-4{margin-bottom:16px}.flex-col{flex-direction:column}.font-bold{font-weight:700}.text-primary{color:var(--text-primary)}.text-center{text-align:center}.stat-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;text-align:center;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 2px 8px #0003}.stat-card:hover{border-color:var(--border-hover);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d}.grid{display:grid}.error-boundary{display:flex;align-items:center;justify-content:center;min-height:300px;padding:32px}.error-boundary-content{text-align:center;max-width:400px;background:var(--bg-card);padding:32px;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);box-shadow:0 8px 32px #0006}.error-boundary-content .error-icon{color:var(--accent-danger);margin-bottom:24px}.error-boundary-content h2{font-size:1.5rem;margin-bottom:12px;color:var(--text-primary);font-weight:700;letter-spacing:-.5px}.error-boundary-content .error-message{color:var(--text-secondary);margin-bottom:24px;font-size:.875rem}.loading-skeleton{display:flex;flex-direction:column;gap:12px}.skeleton-line{background:linear-gradient(90deg,var(--bg-card) 0%,var(--bg-card-hover) 50%,var(--bg-card) 100%);background-size:200% 100%;animation:skeleton-shimmer 1.5s infinite;border-radius:var(--radius-sm)}@keyframes skeleton-shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}.page-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:200px;gap:var(--space-4);color:var(--text-secondary)}.loading-spinner{width:32px;height:32px;border:3px solid var(--border-subtle);border-top-color:var(--accent-primary);border-radius:50%;animation:spin 1s linear infinite}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-8);text-align:center;color:var(--text-secondary)}.empty-state-icon{color:var(--text-tertiary);margin-bottom:var(--space-4)}.empty-state h3{font-size:var(--font-size-lg);color:var(--text-primary);margin-bottom:var(--space-2)}.empty-state p{font-size:var(--font-size-sm);max-width:300px}.servers-page{display:flex;flex:1;min-height:0;min-width:0;position:relative;overflow:hidden}.servers-canvas-area{flex:1;min-width:0;min-height:0;position:relative;overflow:hidden}.canvas-sidebar{position:relative;width:300px;min-width:300px;height:100%;background:var(--bg-panel);border-left:1px solid var(--border-subtle);display:flex;flex-direction:column;overflow:hidden;flex-shrink:0;transition:width .3s cubic-bezier(.16,1,.3,1),min-width .3s cubic-bezier(.16,1,.3,1)}.canvas-sidebar.collapsed{width:0;min-width:0;border-left:none}.sidebar-toggle{position:absolute;right:300px;top:50%;transform:translateY(-50%);z-index:101;width:24px;height:48px;background:var(--bg-card);border:1px solid var(--border-subtle);border-right:none;border-radius:8px 0 0 8px;color:var(--text-secondary);cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .3s cubic-bezier(.16,1,.3,1)}.sidebar-toggle:hover{background:var(--bg-card-hover);color:var(--text-primary)}.sidebar-toggle.collapsed{right:0;border-right:1px solid var(--border-subtle);border-radius:8px 0 0 8px}.canvas-sidebar-header{padding:20px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.canvas-sidebar-header h3{font-size:.95rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.server-count-badge{background:var(--accent-primary);color:#000;font-size:.7rem;font-weight:700;padding:2px 8px;border-radius:100px}.canvas-sidebar-list{flex:1;overflow-y:auto;padding:12px}.server-list-item{padding:16px 20px;margin-bottom:12px;background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-subtle);cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);position:relative;box-shadow:0 2px 8px #0003}.server-list-item:hover{background:var(--bg-card-hover);border-color:var(--border-hover);transform:translate(-4px);box-shadow:0 4px 16px #0000004d}.server-list-item.selected{border-color:var(--accent-primary);background:#d4f2380d;box-shadow:0 0 0 1px var(--accent-glow)}.server-list-item-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:8px}.server-list-item-name{font-weight:700;font-size:1rem;color:var(--text-primary);display:flex;align-items:center;gap:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.server-list-item-ip{font-size:.875rem;color:var(--text-tertiary);font-family:var(--font-mono)}.server-list-item-footer{display:flex;justify-content:space-between;align-items:center;margin-top:12px}.server-list-item-status{font-size:.75rem;padding:4px 10px;border-radius:var(--radius-sm);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.server-list-item-status.online{background:#10b98126;color:var(--accent-success)}.server-list-item-status.offline{background:#ef444426;color:var(--accent-danger)}.server-list-item-role{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase}.server-list-item-delete{position:absolute;top:10px;right:10px;opacity:0;transition:opacity .2s}.server-list-item:hover .server-list-item-delete{opacity:1}.canvas-sidebar-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:32px;text-align:center}.canvas-sidebar-empty-icon{width:64px;height:64px;border-radius:20px;background:var(--bg-card);display:flex;align-items:center;justify-content:center;margin-bottom:16px;color:var(--text-tertiary)}.canvas-sidebar-empty h4{font-size:1rem;color:var(--text-primary);margin-bottom:8px}.canvas-sidebar-empty p{font-size:.8rem;color:var(--text-secondary);line-height:1.5}.server-detail-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:200;opacity:0;visibility:hidden;transition:all .3s}.server-detail-overlay.open{opacity:1;visibility:visible}.server-detail-panel{position:fixed;top:0;right:0;bottom:0;width:420px;background:var(--bg-panel);border-left:1px solid var(--border-subtle);z-index:250;transform:translate(100%);transition:transform .3s cubic-bezier(.16,1,.3,1);display:flex;flex-direction:column;box-shadow:-20px 0 60px #00000080}.server-detail-panel.open{transform:translate(0)}.server-detail-header{padding:24px;border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:flex-start}.server-detail-title{display:flex;align-items:center;gap:12px}.server-detail-title h2{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.server-detail-close{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:10px;padding:8px;color:var(--text-secondary);cursor:pointer;transition:all .2s}.server-detail-close:hover{background:var(--bg-card-hover);color:var(--text-primary)}.server-detail-body{flex:1;overflow-y:auto;padding:24px}.server-detail-section{margin-bottom:28px}.server-detail-section-title{font-size:.75rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:600;margin-bottom:12px;letter-spacing:.5px}.server-detail-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.server-detail-info-item{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:14px}.server-detail-info-label{font-size:.7rem;text-transform:uppercase;color:var(--text-tertiary);margin-bottom:4px}.server-detail-info-value{font-size:.95rem;color:var(--text-primary);font-weight:500}.server-detail-info-value.mono{font-family:var(--font-mono);font-size:.85rem}.server-quick-actions{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.server-quick-action{display:flex;align-items:center;justify-content:center;gap:8px;padding:16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);font-size:.875rem;font-weight:600}.server-quick-action:hover{background:var(--bg-card-hover);border-color:var(--border-hover);color:var(--text-primary);transform:translateY(-1px)}.server-quick-action.primary{background:var(--accent-primary);border-color:var(--accent-primary);color:#000;font-weight:600;box-shadow:0 4px 12px var(--accent-glow)}.server-quick-action.primary:hover{filter:brightness(1.1);box-shadow:0 6px 16px var(--accent-glow)}.server-quick-action.danger{border-color:#ef44444d;color:var(--accent-danger)}.server-quick-action.danger:hover{background:#ef44441a;border-color:var(--accent-danger)}.server-quick-action.warning{border-color:#f59e0b4d;color:var(--accent-warning)}.server-quick-action.warning:hover{background:#ff98001a;border-color:#ff9800}.server-quick-action:disabled{opacity:.5;cursor:not-allowed}.server-metrics-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}.server-metric-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:12px;padding:16px;text-align:center}.server-metric-value{font-size:1.5rem;font-weight:700;color:var(--text-primary);line-height:1}.server-metric-label{font-size:.7rem;text-transform:uppercase;color:var(--text-tertiary);margin-top:6px}.fab{position:absolute;bottom:32px;right:332px;width:64px;height:64px;background:var(--accent-primary);border:none;border-radius:20px;display:flex;align-items:center;justify-content:center;color:#000;cursor:pointer;box-shadow:0 8px 32px var(--accent-glow);transition:all .3s cubic-bezier(.16,1,.3,1);z-index:150}.fab:hover{transform:scale(1.05) translateY(-4px);box-shadow:0 12px 40px var(--accent-glow)}.fab:active{transform:scale(.95)}.server-node{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;min-width:240px;transition:all .3s cubic-bezier(.16,1,.3,1);box-shadow:0 4px 24px #0006;position:relative}.server-node:before{content:"";position:absolute;top:-2px;right:-2px;bottom:-2px;left:-2px;border-radius:18px;background:transparent;transition:all .3s;z-index:-1}.server-node:hover{border-color:var(--accent-primary);transform:translateY(-4px);box-shadow:0 12px 40px #00000080}.server-node:hover:before{background:linear-gradient(135deg,rgba(212,242,56,.15),transparent)}.server-node.selected{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow),0 12px 40px #00000080}.server-node.online:after{content:"";position:absolute;top:16px;right:16px;width:10px;height:10px;background:var(--accent-success);border-radius:50%;box-shadow:0 0 12px var(--accent-success);animation:pulse-online 2s infinite}.server-node.offline:after{content:"";position:absolute;top:16px;right:16px;width:10px;height:10px;background:var(--accent-danger);border-radius:50%}.server-node.planned:after{content:"";position:absolute;top:16px;right:16px;width:10px;height:10px;background:#9e9e9e;border-radius:50%}.server-node.maintenance:after{content:"";position:absolute;top:16px;right:16px;width:10px;height:10px;background:var(--accent-warning);border-radius:50%}@keyframes pulse-online{0%,to{opacity:1;box-shadow:0 0 12px var(--accent-success)}50%{opacity:.6;box-shadow:0 0 20px var(--accent-success)}}.server-node-header{display:flex;align-items:center;gap:10px;margin-bottom:14px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.server-node-name{font-weight:700;font-size:.95rem;flex:1;color:var(--text-primary)}.server-node-role{font-size:.65rem;padding:3px 8px;background:#ffffff14;border-radius:6px;color:var(--text-secondary);text-transform:uppercase;font-weight:600}.server-node-role.vpn{background:#4caf5026;color:#4caf50}.server-node-role.relay{background:#2196f326;color:#2196f3}.server-node-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;font-size:.75rem;color:var(--text-secondary)}.server-node-stat{display:flex;align-items:center;gap:5px;background:#ffffff08;padding:6px 8px;border-radius:6px}.server-node-stat svg{opacity:.7}.client-node{background:linear-gradient(135deg,var(--accent-primary) 0%,#b8d42a 100%);border-radius:50%;width:72px;height:72px;display:flex;align-items:center;justify-content:center;color:#000;font-weight:800;font-size:.8rem;box-shadow:0 0 30px var(--accent-glow),0 8px 32px #0000004d;border:3px solid #000;animation:client-pulse 3s ease-in-out infinite;position:relative}.client-node:before{content:"";position:absolute;top:-8px;right:-8px;bottom:-8px;left:-8px;border-radius:50%;border:2px dashed var(--accent-primary);opacity:.3;animation:client-ring 10s linear infinite}@keyframes client-pulse{0%,to{box-shadow:0 0 30px var(--accent-glow),0 8px 32px #0000004d}50%{box-shadow:0 0 50px var(--accent-glow),0 8px 32px #0000004d}}@keyframes client-ring{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.react-flow__edge-path{stroke:var(--accent-primary)!important;stroke-width:2px!important}.react-flow__edge.animated .react-flow__edge-path{stroke-dasharray:8;animation:edge-flow 1s linear infinite}@keyframes edge-flow{0%{stroke-dashoffset:16}to{stroke-dashoffset:0}}.react-flow__controls{background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;box-shadow:var(--shadow-soft)!important;border-radius:14px!important;overflow:hidden;padding:6px!important;left:20px!important;bottom:20px!important}.react-flow__controls-button{border:none!important;background:transparent!important;color:var(--text-secondary)!important;border-radius:8px!important;width:32px!important;height:32px!important;margin:2px!important}.react-flow__controls-button:hover{background:var(--bg-card-hover)!important;color:var(--text-primary)!important}.react-flow__minimap{background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;border-radius:14px!important;bottom:20px!important;right:20px!important;box-shadow:var(--shadow-soft)!important}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:24px;animation:fadeIn .2s ease-out}.modal-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:32px;width:100%;max-width:560px;max-height:90vh;display:flex;flex-direction:column;box-shadow:0 24px 64px #0009;animation:slideUp .3s cubic-bezier(.16,1,.3,1)}.modal-title{color:var(--text-primary);margin-bottom:24px;font-size:1.5rem;font-weight:700;letter-spacing:-.5px}.modal-actions{display:flex;gap:16px;justify-content:flex-end;margin-top:32px;flex-wrap:wrap}.modal-actions .btn{min-width:120px}.modal-form-content{overflow-y:auto;padding-right:8px}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{opacity:0;transform:translateY(20px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}@keyframes pulse{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(1.2)}}.react-flow__minimap{border-radius:12px!important;overflow:hidden}.react-flow__controls{border-radius:12px!important;background:var(--bg-card)!important;border:1px solid var(--border-subtle)!important;box-shadow:0 4px 16px #0000004d!important}.react-flow__controls-button{background:var(--bg-card)!important;border-color:var(--border-subtle)!important;fill:var(--text-primary)!important}.react-flow__controls-button:hover{background:var(--bg-card-hover)!important}.react-flow__edge-path{stroke-width:2!important}.react-flow__edge.animated path{stroke-dasharray:5;animation:edgeFlow 1s linear infinite}@keyframes edgeFlow{0%{stroke-dashoffset:10}to{stroke-dashoffset:0}}.react-flow__handle{width:14px!important;height:28px!important;border-radius:4px!important;border:2px solid var(--accent-primary)!important;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))!important;opacity:1!important;visibility:visible!important;pointer-events:all!important}.react-flow__handle.react-flow__handle-left,.react-flow__handle-left,.react-flow__handle[data-handlepos=left]{left:-8px!important;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary))!important;border-color:#d4f238cc!important;box-shadow:0 0 12px #d4f23899!important}.react-flow__handle.react-flow__handle-right,.react-flow__handle-right,.react-flow__handle[data-handlepos=right]{right:-8px!important;background:linear-gradient(135deg,var(--accent-secondary),var(--accent-primary))!important;border-color:#8b5cf6cc!important;box-shadow:0 0 12px #8b5cf699!important}.react-flow__handle:hover{transform:scale(1.3)!important;box-shadow:0 0 20px #d4f238e6!important}.react-flow__handle.connecting,.react-flow__handle.connectingto,.react-flow__handle.connectingfrom{background:var(--accent-primary)!important;box-shadow:0 0 20px var(--accent-primary)!important}.server-node-container .react-flow__handle{opacity:1!important;visibility:visible!important}.server-hero-header{display:flex;align-items:center;gap:16px;padding-bottom:24px;margin-bottom:24px;border-bottom:1px solid var(--border-subtle)}.server-hero-flag{font-size:3.5rem;line-height:1;filter:drop-shadow(0 0 20px rgba(0,0,0,.5))}.server-hero-info h2{font-size:1.75rem;font-weight:700;margin:0 0 8px;color:var(--text-primary);line-height:1.2}.server-hero-badges{display:flex;gap:8px}.server-hero-badge{display:inline-flex;align-items:center;gap:6px;padding:4px 10px;border-radius:100px;font-size:.75rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.server-hero-badge.online{background:#4caf5026;color:#4caf50;border:1px solid rgba(76,175,80,.3)}.server-hero-badge.offline{background:#f4433626;color:#f44336;border:1px solid rgba(244,67,54,.3)}.metrics-bento-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:32px}.metric-bento-card{background:#ffffff08;border:1px solid var(--border-subtle);border-radius:16px;padding:16px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;transition:all .2s}.metric-bento-card:hover{background:#ffffff0f;transform:translateY(-2px)}.metric-bento-value{font-size:1.4rem;font-weight:700;color:var(--text-primary)}.metric-bento-label{font-size:.7rem;color:var(--text-tertiary);text-transform:uppercase;font-weight:600;letter-spacing:.5px}.action-center-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;margin-bottom:32px}.action-btn-stack{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:12px;padding:24px 16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);color:var(--text-secondary);transition:all .3s cubic-bezier(.16,1,.3,1);cursor:pointer;min-height:120px;box-shadow:0 2px 8px #0003}.action-btn-stack:hover:not(:disabled){background:var(--bg-card-hover);color:var(--text-primary);transform:translateY(-2px);box-shadow:0 8px 24px #0000004d;border-color:var(--border-hover)}.action-btn-stack.primary{background:#d4f2381a;border-color:#d4f2384d;color:var(--accent-primary)}.action-btn-stack.primary:hover:not(:disabled){background:#d4f23833;box-shadow:0 8px 24px #d4f23840}.action-btn-stack.danger{color:var(--accent-danger);border-color:#ef444433}.action-btn-stack.danger:hover:not(:disabled){background:#ef44441a;border-color:var(--accent-danger)}.action-btn-label{font-size:.875rem;font-weight:600}.info-list-compact{display:flex;flex-direction:column;gap:0;background:#0003;border-radius:var(--radius-lg);border:1px solid var(--border-subtle);overflow:hidden}.info-item-row{display:flex;justify-content:space-between;align-items:center;padding:16px 20px;border-bottom:1px solid var(--border-subtle)}.info-item-row:last-child{border-bottom:none}.info-label{color:var(--text-tertiary);font-size:.875rem;display:flex;align-items:center;gap:8px}.info-value{color:var(--text-primary);font-family:var(--font-mono);font-size:.875rem}.segmented-control{display:flex;background:#0000004d;padding:6px;border-radius:var(--radius-md);gap:6px;width:100%}.segmented-option{flex:1;text-align:center;padding:12px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s cubic-bezier(.16,1,.3,1);border:1px solid transparent}.segmented-option:hover{color:var(--text-primary)}.segmented-option.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 2px 8px #0000004d;border-color:var(--border-subtle)}.segmented-option.active[data-value=vpn]{background:#d4f23826;color:var(--accent-primary);border-color:#d4f2384d}.segmented-option.active[data-value=relay]{background:#8b5cf626;color:var(--accent-secondary);border-color:#8b5cf64d}.xray-config-panel{background:#0003;border-radius:16px;border:1px solid var(--border-subtle);padding:20px;margin-top:16px}.xray-config-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-subtle)}.xray-title{font-size:.8rem;text-transform:uppercase;color:var(--accent-primary);font-weight:700;letter-spacing:1px;display:flex;align-items:center;gap:8px}.users-stats-bar{display:flex;gap:var(--space-2)}.users-stat-card{display:flex;align-items:center;gap:12px;padding:12px 16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);cursor:pointer;transition:all .3s cubic-bezier(.16,1,.3,1);font-family:inherit;color:var(--text-primary);box-shadow:0 2px 8px #0003}.users-stat-card:hover{border-color:var(--border-hover);background:var(--bg-card-hover);transform:translateY(-1px);box-shadow:0 4px 12px #0000004d}.users-stat-card.active{border-color:var(--accent-primary);background:#d4f2381a;box-shadow:0 0 0 1px var(--accent-glow)}.users-stat-card .stat-value{font-weight:800;font-size:1.25rem}.users-stat-card .stat-label{font-size:.75rem;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.users-table{width:100%}.users-table th{padding:16px 24px;font-size:.75rem;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);border-bottom:1px solid var(--border-subtle);font-weight:600}.users-table td{padding:16px 24px;border-bottom:1px solid var(--border-subtle);vertical-align:middle}.users-table tr.banned-row{opacity:.6}.users-table tr:hover{background:#ffffff05}.user-cell{display:flex;align-items:center;gap:16px}.user-avatar{width:48px;height:48px;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1rem;color:#000;flex-shrink:0;overflow:hidden;box-shadow:0 4px 12px #0000004d}.user-avatar.small{width:32px;height:32px;font-size:var(--font-size-xs)}.user-avatar img{width:100%;height:100%;object-fit:cover}.user-info{display:flex;flex-direction:column;gap:2px;min-width:0}.user-name{font-weight:600;font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-username{display:inline-flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--accent-primary);text-decoration:none;transition:color .2s}.user-username:hover{color:var(--accent-secondary)}.user-id{font-size:.65rem;color:var(--text-tertiary);font-family:var(--font-mono)}.subscription-info{display:flex;flex-direction:column;gap:2px}.subscription-info.expired{display:flex;flex-direction:row;align-items:center;gap:6px;color:var(--text-tertiary);font-size:var(--font-size-xs)}.subscription-dates{display:flex;flex-direction:column;gap:2px}.date-row{display:flex;align-items:center;gap:4px;font-size:var(--font-size-xs);color:var(--text-secondary)}.days-left{font-size:.65rem;color:#22c55e;font-weight:600}.days-left.warning{color:#f59e0b}.no-subscription{font-size:var(--font-size-xs);color:var(--text-tertiary)}.status-badge.neutral{background:#ffffff14;color:var(--text-secondary)}.action-buttons{display:flex;gap:4px;justify-content:flex-end}.btn.btn-ghost{background:transparent;border:none;color:var(--text-secondary)}.btn.btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.pagination-bar{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3) var(--space-4);border-top:1px solid var(--border-subtle);background:#0003}.pagination-buttons{display:flex;align-items:center;gap:var(--space-2)}.page-indicator{font-size:var(--font-size-xs);color:var(--text-secondary);padding:0 var(--space-2)}.users-toolbar{display:flex;align-items:center;justify-content:space-between;gap:12px;flex-wrap:wrap}.users-filters{display:flex;align-items:center;gap:6px;flex-wrap:wrap}.filter-chip{display:flex;align-items:center;gap:8px;padding:6px 16px;border-radius:var(--radius-md);border:1px solid var(--border-subtle);background:var(--bg-card);cursor:pointer;font-size:.875rem;font-weight:600;font-family:var(--font-sans);color:var(--text-secondary);transition:all .2s cubic-bezier(.16,1,.3,1);white-space:nowrap}.filter-chip:hover{border-color:var(--border-hover);background:var(--bg-card-hover);color:var(--text-primary);transform:translateY(-1px)}.filter-chip.active{border-color:var(--chip-color, var(--text-primary));background:color-mix(in srgb,var(--chip-color, var(--text-primary)) 10%,transparent);color:var(--chip-color, var(--text-primary));box-shadow:0 2px 8px color-mix(in srgb,var(--chip-color, var(--text-primary)) 20%,transparent)}.filter-chip .chip-count{padding:2px 8px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:700;line-height:1.4;background:var(--bg-tertiary);color:var(--text-secondary);transition:all .2s ease}.filter-chip.active .chip-count{background:var(--chip-color, var(--text-primary));color:#000}.users-actions{display:flex;gap:12px;align-items:center}.users-table tr.selected-row td{background:color-mix(in srgb,var(--accent-primary) 10%,transparent)}.users-table tr.user-row-interactive{transition:background .2s ease}.drawer-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);z-index:900;animation:fadeIn .2s ease-out}.user-drawer{position:fixed;top:0;right:0;bottom:0;width:480px;max-width:92vw;background:var(--bg-panel);border-left:1px solid var(--border-subtle);z-index:901;display:flex;flex-direction:column;box-shadow:-12px 0 48px #00000080;animation:slideInRight .3s cubic-bezier(.16,1,.3,1)}@keyframes slideInRight{0%{opacity:0;transform:translate(100%)}to{opacity:1;transform:translate(0)}}.user-drawer-header{display:flex;align-items:center;gap:16px;padding:24px;border-bottom:1px solid var(--border-subtle);background:var(--bg-card);flex-shrink:0}.user-drawer-header .drawer-avatar{width:56px;height:56px;border-radius:var(--radius-md);overflow:hidden;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:1.5rem;border:2px solid var(--border-subtle);flex-shrink:0;background:linear-gradient(135deg,var(--bg-card-hover),var(--bg-card))}.user-drawer-header .drawer-avatar img{width:100%;height:100%;object-fit:cover}.user-drawer-header .drawer-user-meta{flex:1;min-width:0}.user-drawer-header .drawer-user-name{font-size:1.25rem;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;letter-spacing:-.5px}.user-drawer-header .drawer-user-sub{display:flex;align-items:center;gap:8px;margin-top:4px;font-size:.875rem}.user-drawer-body{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.drawer-section{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:20px;box-shadow:0 2px 8px #0003}.drawer-section-title{font-size:.75rem;color:var(--text-tertiary);font-weight:700;text-transform:uppercase;letter-spacing:.5px;margin-bottom:16px;display:flex;align-items:center;gap:8px}.drawer-section-title .section-extra{margin-left:auto;font-size:.875rem;text-transform:none;letter-spacing:0}.drawer-info-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.drawer-info-item{display:flex;flex-direction:column;gap:4px}.drawer-info-item .info-label{font-size:.75rem;color:var(--text-tertiary)}.drawer-info-item .info-value{font-size:.875rem;color:var(--text-primary);font-weight:500}.drawer-info-item .info-value.mono{font-family:var(--font-mono);-webkit-user-select:all;user-select:all}.drawer-info-item.full-width{grid-column:1 / -1}.drawer-list-item{display:flex;justify-content:space-between;align-items:center;padding:10px 14px;background:#0003;border-radius:var(--radius-md);font-size:.875rem}.drawer-list-item+.drawer-list-item{margin-top:8px}.drawer-actions{display:flex;gap:12px;flex-wrap:wrap;padding:24px;border-top:1px solid var(--border-subtle);background:var(--bg-card);flex-shrink:0}.drawer-actions .btn{flex:1;min-width:0;gap:8px;justify-content:center}.drawer-modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:2001;display:flex;align-items:center;justify-content:center;animation:fadeIn .15s ease}.drawer-modal{background:var(--bg-card);border:1px solid var(--border-primary);border-radius:12px;padding:20px;max-width:380px;width:90vw;box-shadow:0 20px 60px #0006}.broadcast-modal{max-width:600px;width:90vw;max-height:90vh;overflow-y:auto}.modal-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:var(--space-3);margin-bottom:var(--space-3);border-bottom:1px solid var(--border-subtle)}.modal-title{display:flex;align-items:center;gap:var(--space-2);font-size:var(--font-size-lg);font-weight:700;margin:0}.modal-close{background:transparent;border:none;color:var(--text-secondary);cursor:pointer;padding:6px;border-radius:var(--radius-sm);transition:all .2s}.modal-close:hover{background:var(--bg-hover);color:var(--text-primary)}.modal-body{flex:1;overflow-y:auto;padding:var(--space-1) 0}.modal-recipient{display:flex;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-hover);border-radius:var(--radius-md);margin-bottom:var(--space-4)}.audience-selector{position:relative}.audience-trigger{display:flex;align-items:center;gap:16px;width:100%;padding:16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);cursor:pointer;font-family:inherit;color:var(--text-primary);transition:all .2s;text-align:left;box-shadow:var(--shadow-sm)}.audience-trigger:hover{border-color:var(--border-hover);box-shadow:var(--shadow-md)}.audience-icon{width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:color-mix(in srgb,var(--accent-primary) 15%,transparent);border-radius:var(--radius-md);color:var(--accent-primary)}.audience-info{flex:1}.audience-label{font-weight:600;font-size:1rem}.audience-description{font-size:.875rem;color:var(--text-secondary);margin-top:4px}.audience-count{display:flex;align-items:center}.count-badge{background:var(--accent-primary);color:#000;font-weight:700;font-size:.75rem;padding:4px 12px;border-radius:999px}.audience-trigger svg.rotated{transform:rotate(180deg)}.audience-dropdown{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:100;overflow:hidden;padding:8px}.audience-option{display:flex;align-items:center;gap:12px;width:100%;padding:12px 16px;background:transparent;border:none;border-radius:var(--radius-md);cursor:pointer;font-family:inherit;color:var(--text-primary);text-align:left;transition:background .15s}.audience-option:hover{background:var(--bg-hover)}.audience-option.active{background:color-mix(in srgb,var(--accent-primary) 10%,transparent);color:var(--accent-primary)}.input-label-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2)}.format-toggle{display:flex;background:var(--bg-hover);border-radius:var(--radius-sm);padding:2px}.format-btn{padding:4px 10px;font-size:var(--font-size-xs);font-weight:600;background:transparent;border:none;border-radius:var(--radius-xs);color:var(--text-secondary);cursor:pointer;transition:all .15s;font-family:inherit}.format-btn.active{background:var(--bg-card);color:var(--text-primary);box-shadow:0 1px 3px #0003}.formatting-toolbar{display:flex;gap:4px;padding:8px;background:var(--bg-hover);border:1px solid var(--border-subtle);border-bottom:none;border-radius:var(--radius-lg) var(--radius-lg) 0 0}.formatting-toolbar button{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:var(--radius-md);color:var(--text-secondary);cursor:pointer;transition:all .15s}.formatting-toolbar button:hover{background:var(--bg-card);color:var(--text-primary);box-shadow:var(--shadow-sm)}.formatting-toolbar button.active{background:var(--accent-primary);color:#000;box-shadow:var(--shadow-sm)}.toolbar-separator{width:1px;background:var(--border-subtle);margin:0 8px}.formatting-toolbar+.input,.formatting-toolbar+.message-preview{border-top-left-radius:0;border-top-right-radius:0}.message-preview{min-height:150px;padding:16px;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);box-shadow:inset 0 2px 4px #0000001a}.preview-image{margin-bottom:16px;border-radius:var(--radius-md);overflow:hidden}.preview-image img{max-width:100%;max-height:200px;object-fit:contain}.preview-text{font-size:.875rem;line-height:1.6;color:var(--text-primary)}.preview-text b{font-weight:700}.preview-text code{background:#0000004d;padding:2px 6px;border-radius:4px;font-family:var(--font-mono);font-size:.9em}.preview-buttons{margin-top:16px;display:flex;flex-direction:column;gap:8px}.preview-button-row{display:flex;gap:8px}.preview-button{flex:1;padding:10px 16px;background:color-mix(in srgb,var(--accent-primary) 15%,transparent);border:1px solid var(--accent-primary);border-radius:var(--radius-md);color:var(--accent-primary);text-align:center;text-decoration:none;font-size:.875rem;font-weight:600;transition:all .15s}.preview-button:hover{background:color-mix(in srgb,var(--accent-primary) 25%,transparent)}.inline-buttons-editor{display:flex;flex-direction:column;gap:16px;padding:16px;background:var(--bg-hover);border-radius:var(--radius-lg);border:1px solid var(--border-subtle)}.button-row{display:flex;flex-direction:column;gap:12px;padding:16px;background:var(--bg-card);border-radius:var(--radius-md);border:1px solid var(--border-subtle);box-shadow:var(--shadow-sm)}.row-label{font-size:.75rem;text-transform:uppercase;color:var(--text-tertiary);font-weight:700;letter-spacing:.5px}.buttons-list{display:flex;flex-direction:column;gap:12px}.button-item{display:flex;gap:12px;align-items:center}.button-item .input{flex:1;padding:10px 12px;font-size:.875rem}.input-hint{font-size:.75rem;color:var(--text-tertiary);margin-top:4px}.modal-actions{display:flex;justify-content:flex-end;gap:var(--space-2);margin-top:var(--space-4);padding-top:var(--space-3);border-top:1px solid var(--border-subtle)}.modal-actions .btn{display:flex;align-items:center;gap:var(--space-2)}.btn.btn-sm{padding:6px 12px;font-size:var(--font-size-xs)}.animate-spin{animation:spin 1s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.skeleton-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:24px;overflow:hidden;box-shadow:var(--shadow-sm)}.skeleton-card .skeleton-line{height:16px;margin-bottom:12px;border-radius:var(--radius-sm)}.skeleton-card .skeleton-line:last-child{margin-bottom:0}.skeleton-card .skeleton-line.lg{height:28px;width:60%}.skeleton-card .skeleton-line.sm{height:12px;width:40%}.pulse-dot{width:10px;height:10px;border-radius:50%;background:#22c55e;display:inline-block;animation:pulse-glow 2s ease-in-out infinite;box-shadow:0 0 8px #22c55e99}.pulse-dot.warning{background:#f59e0b;box-shadow:0 0 8px #f59e0b99}.pulse-dot.accent{background:var(--accent-primary);box-shadow:0 0 8px var(--accent-glow)}@keyframes pulse-glow{0%,to{opacity:1;transform:scale(1)}50%{opacity:.5;transform:scale(.85)}}.data-transition{transition:all .5s cubic-bezier(.16,1,.3,1)}.segmented-control{display:inline-flex;background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:4px;gap:4px;box-shadow:inset 0 2px 4px #0000000d}.segmented-option{padding:8px 16px;border-radius:var(--radius-sm);font-size:.875rem;font-weight:600;color:var(--text-secondary);cursor:pointer;transition:all .2s;-webkit-user-select:none;user-select:none}.segmented-option:hover{color:var(--text-primary);background:var(--bg-hover)}.segmented-option.active{background:var(--accent-primary);color:#000;box-shadow:var(--shadow-sm)}.bento-card.active-stat{background:var(--bg-card-hover);box-shadow:var(--shadow-soft)}.status-badge svg{flex-shrink:0}@media (max-width: 1200px){.bento-grid{grid-template-columns:repeat(2,1fr)!important}}@media (max-width: 800px){.bento-grid{grid-template-columns:1fr!important}}@keyframes skeleton-pulse{0%,to{opacity:.4}50%{opacity:.8}}.skeleton-pulse{animation:skeleton-pulse 1.5s ease-in-out infinite}.card-hover{transition:border-color .2s,transform .15s}.card-hover:hover{border-color:var(--accent-primary)!important;transform:translateY(-1px)}.btn-hover{transition:opacity .2s,background .2s}.btn-hover:hover{opacity:.85}.row-hover{transition:background .15s}.row-hover:hover{background:var(--bg-elevated)!important}.settings-section-title{margin-bottom:16px}.settings-section-title h3{font-size:.9rem;font-weight:600;color:var(--text-primary);display:flex;align-items:center;gap:8px}.settings-section-title p{font-size:.75rem;color:var(--text-tertiary);margin-top:4px}.settings-row{display:flex;justify-content:space-between;align-items:center;padding:12px 0;border-bottom:1px solid var(--border-subtle)}.settings-row-label{font-size:.8rem;font-weight:500;color:var(--text-primary)}.settings-row-desc{font-size:.7rem;color:var(--text-tertiary);margin-top:2px}.settings-row-right{flex-shrink:0}.settings-card{background:var(--bg-card);border:1px solid var(--border-subtle);border-radius:14px;padding:20px;margin-bottom:16px}.toggle-switch{width:40px;height:22px;border-radius:11px;border:none;position:relative;transition:background .2s;cursor:pointer}.toggle-switch:disabled{cursor:default;opacity:.5}.toggle-switch .toggle-knob{width:16px;height:16px;border-radius:50%;background:var(--color-toggle-knob);position:absolute;top:3px;transition:left .2s}.btn-icon-inline{display:flex;align-items:center;gap:6px}.flex-row-wrap{display:flex;gap:10px;flex-wrap:wrap}.passkey-row{display:flex;justify-content:space-between;align-items:center;padding:10px 0;border-bottom:1px solid var(--border-subtle)}.passkey-row-inner{display:flex;align-items:center;gap:10px}.invite-token-box{margin-top:14px;padding:12px;background:var(--bg-card-hover);border-radius:10px;display:flex;justify-content:space-between;align-items:center;gap:10px}.invite-token-code{font-size:.7rem;color:var(--accent-primary);word-break:break-all;flex:1}.health-stat-box{flex:1 1 150px;padding:14px;background:var(--bg-card-hover);border-radius:10px}.health-stat-label{font-size:.65rem;color:var(--text-tertiary);text-transform:uppercase;margin-bottom:6px}.health-stat-value{font-size:1rem;font-weight:700;color:var(--text-primary)}.health-stat-version{font-size:.85rem;font-weight:600;color:var(--text-primary)}
