@import"https://fonts.googleapis.com/css2?family=DM+Sans:ital,opsz,wght@0,9..40,300;0,9..40,400;0,9..40,500;0,9..40,600;0,9..40,700;1,9..40,400&family=JetBrains+Mono:wght@400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0a0c10;--bg-elevated: #0e1016;--surface: #13151c;--surface-2: #181b24;--surface-hover: #1d2029;--surface-active: #22252f;--border: rgba(255, 255, 255, .06);--border-subtle: rgba(255, 255, 255, .04);--border-strong: rgba(255, 255, 255, .1);--text: #e8e9ed;--text-secondary: #a0a3ad;--text-muted: #6b6e7a;--text-faint: #4a4d57;--primary: #6366f1;--primary-hover: #7477f5;--primary-muted: rgba(99, 102, 241, .12);--primary-glow: rgba(99, 102, 241, .06);--green: #34d399;--green-muted: rgba(52, 211, 153, .12);--red: #f87171;--red-muted: rgba(248, 113, 113, .12);--yellow: #fbbf24;--yellow-muted: rgba(251, 191, 36, .12);--blue: #60a5fa;--blue-muted: rgba(96, 165, 250, .12);--radius: 8px;--radius-lg: 12px;--radius-xl: 16px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .25);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .35);--shadow-glow: 0 0 20px rgba(99, 102, 241, .08);--font-sans: "DM Sans", -apple-system, BlinkMacSystemFont, sans-serif;--font-mono: "JetBrains Mono", "SF Mono", "Fira Code", monospace;--transition-fast: .12s ease;--transition: .2s ease;--transition-slow: .35s cubic-bezier(.4, 0, .2, 1)}html{font-size:15px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-sans);background:var(--bg);color:var(--text);line-height:1.5;overflow-x:hidden}#root{min-height:100vh;min-height:100dvh}::selection{background:#6366f14d;color:#fff}.loading-screen{display:flex;align-items:center;justify-content:center;height:100vh;height:100dvh;gap:14px}.loading-spinner{width:20px;height:20px;border:2px solid var(--border-strong);border-top-color:var(--primary);border-radius:50%;animation:spin .7s linear infinite}.loading-text{font-size:.9rem;color:var(--text-muted);font-weight:500;letter-spacing:.02em}@keyframes spin{to{transform:rotate(360deg)}}@keyframes fadeIn{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes slideUp{0%{opacity:0;transform:translateY(12px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-border{0%,to{border-color:#6366f126}50%{border-color:#6366f159}}.login-page{display:flex;align-items:center;justify-content:center;min-height:100vh;min-height:100dvh;padding:24px;background:radial-gradient(ellipse 60% 50% at 50% 0%,rgba(99,102,241,.08) 0%,transparent 60%),var(--bg)}.login-card{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:3rem 2.5rem;text-align:center;max-width:420px;width:100%;box-shadow:var(--shadow-lg),var(--shadow-glow);animation:fadeIn .5s ease}.login-logo{width:56px;height:56px;margin:0 auto 20px;border-radius:var(--radius-lg);object-fit:contain}.login-card h1{font-size:1.5rem;font-weight:700;margin-bottom:6px;letter-spacing:-.02em}.login-subtitle{color:var(--text-muted);font-size:.9rem;margin-bottom:2rem;line-height:1.6}.login-btn{display:inline-flex;align-items:center;justify-content:center;gap:10px;width:100%;padding:12px 24px;background:var(--primary);color:#fff;border:none;border-radius:var(--radius);font-size:.9rem;font-weight:600;font-family:var(--font-sans);cursor:pointer;transition:all var(--transition);letter-spacing:.01em}.login-btn:hover{background:var(--primary-hover);box-shadow:0 0 24px #6366f133;transform:translateY(-1px)}.login-btn:active{transform:translateY(0)}.login-btn svg{width:18px;height:18px}.app{display:flex;flex-direction:column;min-height:100vh;min-height:100dvh}.topbar{display:flex;align-items:center;gap:16px;height:56px;padding:0 24px;background:var(--bg-elevated);border-bottom:1px solid var(--border);position:sticky;top:0;z-index:100;flex-shrink:0}.topbar-brand{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;transition:opacity var(--transition-fast)}.topbar-brand:hover{opacity:.8}.topbar-brand img{width:28px;height:28px;border-radius:6px}.topbar-brand span{font-size:.95rem;font-weight:600;letter-spacing:-.01em;color:var(--text)}.topbar-right{margin-left:auto;display:flex;align-items:center;gap:16px}.ws-indicator{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase;color:var(--text-muted)}.ws-dot{width:7px;height:7px;border-radius:50%;flex-shrink:0}.ws-dot.on{background:var(--green);box-shadow:0 0 6px #34d39980}.ws-dot.off{background:var(--text-faint)}.user-chip{display:flex;align-items:center;gap:8px;padding:4px 12px 4px 6px;background:var(--surface);border:1px solid var(--border);border-radius:20px;font-size:.8rem;color:var(--text-secondary)}.user-avatar{width:24px;height:24px;border-radius:50%;background:var(--primary-muted);color:var(--primary);display:flex;align-items:center;justify-content:center;font-size:.65rem;font-weight:700;text-transform:uppercase}.topbar-logout{background:none;border:1px solid var(--border);color:var(--text-muted);padding:5px 12px;border-radius:var(--radius);font-size:.75rem;font-weight:500;cursor:pointer;font-family:var(--font-sans);transition:all var(--transition-fast)}.topbar-logout:hover{color:var(--text);border-color:var(--border-strong);background:var(--surface)}.hamburger{display:none;background:none;border:none;color:var(--text);font-size:1.2rem;cursor:pointer;padding:4px}.layout{display:flex;flex:1}.sidebar{width:220px;background:var(--bg-elevated);border-right:1px solid var(--border);padding:16px 12px;flex-shrink:0;display:flex;flex-direction:column;gap:2px}.nav-item{display:flex;align-items:center;gap:10px;width:100%;text-align:left;padding:9px 14px;background:none;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius);font-size:.85rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);letter-spacing:.01em}.nav-item:hover{background:var(--surface-hover);color:var(--text-secondary)}.nav-item.active{background:var(--primary-muted);color:var(--primary-hover);font-weight:600}.nav-icon{width:18px;height:18px;opacity:.7;flex-shrink:0}.nav-item.active .nav-icon{opacity:1}.content{flex:1;padding:32px;overflow-x:auto;max-width:1200px;animation:fadeIn .3s ease}.bottom-tabs{display:none}.page-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px;flex-wrap:wrap;gap:12px}.page-title{font-size:1.35rem;font-weight:700;letter-spacing:-.02em;color:var(--text)}.page-title .count{font-weight:400;color:var(--text-muted);font-size:1rem;margin-left:4px}.page-actions{display:flex;align-items:center;gap:8px}.btn{display:inline-flex;align-items:center;justify-content:center;gap:6px;padding:8px 16px;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface);color:var(--text-secondary);cursor:pointer;font-size:.825rem;font-weight:500;font-family:var(--font-sans);transition:all var(--transition-fast);white-space:nowrap;letter-spacing:.01em}.btn:hover{background:var(--surface-hover);color:var(--text);border-color:var(--border-strong)}.btn:active{transform:scale(.98)}.btn:disabled{opacity:.5;cursor:not-allowed}.btn-primary{background:var(--primary);border-color:var(--primary);color:#fff;font-weight:600}.btn-primary:hover{background:var(--primary-hover);border-color:var(--primary-hover);box-shadow:0 0 16px #6366f126;color:#fff}.btn-sm{padding:5px 10px;font-size:.75rem}.btn-danger{background:transparent;border-color:#f871714d;color:var(--red)}.btn-danger:hover{background:var(--red-muted);border-color:#f8717180;color:var(--red)}.btn-ghost{background:none;border:none;padding:6px 10px;color:var(--text-muted)}.btn-ghost:hover{color:var(--text);background:var(--surface-hover)}.table-card{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);overflow:hidden;box-shadow:var(--shadow-sm)}.table-container{overflow-x:auto;-webkit-overflow-scrolling:touch}table{width:100%;border-collapse:collapse;font-size:.85rem}thead{background:var(--surface-2)}th{text-align:left;padding:10px 16px;color:var(--text-muted);font-weight:600;font-size:.72rem;text-transform:uppercase;letter-spacing:.06em;white-space:nowrap;border-bottom:1px solid var(--border)}td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);vertical-align:middle}tbody tr{transition:background var(--transition-fast)}tbody tr:hover td{background:var(--surface-hover)}tbody tr:last-child td{border-bottom:none}td strong{color:var(--text);font-weight:600}td .meta{font-size:.72rem;color:var(--text-faint);margin-top:2px;font-family:var(--font-mono);letter-spacing:.02em}td .timestamp{font-size:.78rem;color:var(--text-muted);font-variant-numeric:tabular-nums}.status-cell{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.status-dot.online{background:var(--green);box-shadow:0 0 6px #34d39966}.status-dot.offline{background:var(--text-faint)}.status-label{font-size:.8rem;font-weight:500}.status-label.online{color:var(--green)}.status-label.offline{color:var(--text-muted)}.dot{display:inline-block;width:8px;height:8px;border-radius:50%;margin-right:6px}.dot.online{background:var(--green);box-shadow:0 0 6px #34d39966}.dot.offline{background:var(--text-faint)}.badge{display:inline-flex;align-items:center;padding:3px 10px;border-radius:20px;font-size:.7rem;font-weight:600;letter-spacing:.03em;text-transform:uppercase;white-space:nowrap}.badge-active{background:var(--green-muted);color:var(--green)}.badge-expired{background:var(--red-muted);color:var(--red)}.badge-source{background:var(--primary-muted);color:var(--primary)}.badge-follower{background:var(--yellow-muted);color:var(--yellow)}.badge-managed{background:#6b6e7a1f;color:var(--text-muted)}select{padding:7px 28px 7px 10px;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text-secondary);font-size:.82rem;font-family:var(--font-sans);cursor:pointer;transition:border-color var(--transition-fast);-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' fill='%236b6e7a' viewBox='0 0 16 16'%3E%3Cpath d='M8 11L3 6h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center}select:hover{border-color:#ffffff26}select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 2px #6366f126}input[type=text],input[type=password],input[type=email]{padding:10px 14px;border-radius:var(--radius);border:1px solid var(--border-strong);background:var(--surface-2);color:var(--text);font-size:.875rem;font-family:var(--font-sans);width:100%;transition:all var(--transition-fast)}input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #6366f11f;background:var(--surface)}input::placeholder{color:var(--text-faint)}input:disabled{opacity:.5;cursor:not-allowed}input[type=checkbox]{width:16px;height:16px;accent-color:var(--primary);cursor:pointer}.code-block{background:var(--bg);border:1px solid var(--border);color:var(--green);padding:14px 18px;border-radius:var(--radius);font-family:var(--font-mono);font-size:.78rem;line-height:1.6;overflow-x:auto;position:relative;word-break:break-all}.code-block code{font-family:inherit}.form-group{margin-bottom:18px}.form-group label{display:block;margin-bottom:6px;font-size:.8rem;font-weight:500;color:var(--text-muted);letter-spacing:.02em}.form-section-title{font-size:.95rem;font-weight:600;color:var(--text);margin-bottom:16px;padding-bottom:10px;border-bottom:1px solid var(--border)}.empty-state{text-align:center;padding:64px 24px;color:var(--text-muted);animation:fadeIn .4s ease}.empty-icon{width:48px;height:48px;margin:0 auto 16px;opacity:.3}.empty-state h3{margin-bottom:8px;color:var(--text-secondary);font-weight:600;font-size:1.05rem}.empty-state p{max-width:360px;margin:0 auto;line-height:1.6;font-size:.88rem}.empty-state code{font-family:var(--font-mono);background:var(--surface-2);padding:2px 6px;border-radius:4px;font-size:.82rem;color:var(--text-secondary)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:200;padding:24px;animation:fadeIn .15s ease}.modal{background:var(--surface);border:1px solid var(--border-strong);border-radius:var(--radius-xl);padding:28px;min-width:420px;max-width:90vw;max-height:85vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .25s ease}.modal h3{font-size:1.1rem;font-weight:700;margin-bottom:18px;letter-spacing:-.01em}.modal-description{color:var(--text-muted);font-size:.88rem;margin-bottom:20px;line-height:1.5}.modal-actions{display:flex;gap:8px;justify-content:flex-end;margin-top:24px}.settings-section{background:var(--surface);border:1px solid var(--border);border-radius:var(--radius-lg);padding:24px;max-width:520px;margin-bottom:20px}@media (max-width: 1024px){.content{padding:24px}}@media (max-width: 768px){html{font-size:14px}.topbar{height:52px;padding:0 16px}.hamburger{display:none}.topbar-brand span{font-size:.9rem}.user-chip,.sidebar{display:none}.bottom-tabs{display:flex;position:fixed;bottom:0;left:0;right:0;height:64px;background:var(--bg-elevated);border-top:1px solid var(--border);z-index:100;padding:0 4px;padding-bottom:env(safe-area-inset-bottom,0)}.tab-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;background:none;border:none;color:var(--text-faint);cursor:pointer;font-family:var(--font-sans);font-size:.65rem;font-weight:500;letter-spacing:.02em;transition:color var(--transition-fast);padding:4px 0;position:relative}.tab-item.active{color:var(--primary)}.tab-item.active:before{content:"";position:absolute;top:0;left:50%;transform:translate(-50%);width:24px;height:2px;background:var(--primary);border-radius:0 0 2px 2px}.tab-item svg,.tab-icon{width:20px;height:20px}.content{padding:20px 16px 80px;max-width:none}.page-header{flex-direction:column;align-items:flex-start}.page-actions{width:100%}.page-actions .btn-primary{flex:1}.table-card{border-radius:var(--radius)}th,td{padding:10px 12px}.modal{min-width:auto;width:100%;margin:0;border-radius:var(--radius-lg)}.modal-overlay{padding:16px;align-items:flex-end}.settings-section{max-width:none}}@media (max-width: 480px){.content{padding:16px 12px 80px}.topbar{padding:0 12px}.topbar-logout{padding:5px 8px;font-size:.7rem}.page-title{font-size:1.15rem}th,td{padding:8px 10px;font-size:.8rem}.btn{padding:7px 12px;font-size:.8rem}select{font-size:.78rem;padding:6px 24px 6px 8px}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#ffffff26}.loading{display:flex;align-items:center;justify-content:center;height:200px;color:var(--text-muted);font-size:.9rem}.ws-status{display:none}
