@import"https://fonts.googleapis.com/css2?family=Inter:wght@400;500;600;700;800&display=swap";:root{--bg-primary: #060a13;--bg-secondary: #0c1221;--bg-elevated: #111a2e;--bg-glass: rgba(12, 18, 33, .75);--bg-glass-hover: rgba(17, 26, 46, .85);--bg-surface: rgba(17, 26, 46, .5);--border: rgba(56, 189, 248, .06);--border-subtle: rgba(255, 255, 255, .04);--border-accent: rgba(56, 189, 248, .15);--border-hover: rgba(56, 189, 248, .25);--accent: #38bdf8;--accent-dim: rgba(56, 189, 248, .1);--accent-glow: 0 0 20px rgba(56, 189, 248, .12);--accent-glow-strong: 0 0 30px rgba(56, 189, 248, .2), 0 0 60px rgba(56, 189, 248, .05);--gradient-accent: linear-gradient(135deg, #38bdf8, #818cf8);--gradient-accent-text: linear-gradient(135deg, #38bdf8, #a78bfa);--text-primary: #f1f5f9;--text-secondary: #64748b;--text-muted: #475569;--success: #34d399;--success-bg: rgba(52, 211, 153, .08);--success-border: rgba(52, 211, 153, .2);--danger: #f87171;--danger-bg: rgba(248, 113, 113, .08);--danger-border: rgba(248, 113, 113, .2);--warning: #fbbf24;--warning-bg: rgba(251, 191, 36, .08);--warning-border: rgba(251, 191, 36, .2);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 12px rgba(0, 0, 0, .3);--shadow-lg: 0 8px 30px rgba(0, 0, 0, .4);--shadow-glow: 0 0 40px rgba(56, 189, 248, .06);--transition: .2s cubic-bezier(.4, 0, .2, 1);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 14px;--radius-xl: 20px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif;background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:#64748b4d;border-radius:3px}::-webkit-scrollbar-thumb:hover{background:#64748b80}.app{display:flex;flex-direction:column;height:100vh}.header{display:flex;align-items:center;justify-content:space-between;padding:0 24px;height:56px;background:var(--bg-glass);backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);border-bottom:1px solid var(--border);position:relative;z-index:10}.header:after{content:"";position:absolute;bottom:0;left:0;right:0;height:1px;background:linear-gradient(90deg,transparent,var(--accent-dim),transparent)}.header-left{display:flex;align-items:center;gap:28px}.brand{display:flex;align-items:center;gap:10px;text-decoration:none}.brand-icon{color:var(--accent);opacity:.9}.brand h1{font-size:15px;font-weight:700;letter-spacing:-.02em;background:var(--gradient-accent-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.header-nav{display:flex;gap:2px;background:var(--bg-surface);border-radius:8px;padding:3px;border:1px solid var(--border)}.header-nav a{padding:6px 16px;border-radius:6px;font-size:12.5px;font-weight:600;color:var(--text-secondary);text-decoration:none;transition:all var(--transition);letter-spacing:.01em}.header-nav a:hover{color:var(--text-primary);background:#ffffff0a}.header-nav a.active{background:var(--accent-dim);color:var(--accent);box-shadow:var(--accent-glow)}.header-right{display:flex;align-items:center;gap:16px}.header .status{display:flex;align-items:center;gap:8px;font-size:12px;font-weight:500;color:var(--text-secondary)}.header .status .dot{width:7px;height:7px;border-radius:50%;background:var(--success);box-shadow:0 0 8px #34d39980;animation:pulse-glow 2s ease-in-out infinite}.header .status .dot.offline{background:var(--danger);box-shadow:0 0 8px #f8717180;animation:none}@keyframes pulse-glow{0%,to{box-shadow:0 0 8px #34d39980}50%{box-shadow:0 0 14px #34d399b3}}.main{display:flex;flex:1;overflow:hidden}.sidebar{width:280px;background:var(--bg-secondary);border-right:1px solid var(--border);padding:16px;display:flex;flex-direction:column;gap:16px;overflow-y:auto}.sidebar h3{font-size:10px;text-transform:uppercase;letter-spacing:.1em;color:var(--text-muted);font-weight:700;margin-bottom:4px}.model-list{display:flex;flex-direction:column;gap:2px}.provider-group{margin-bottom:8px}.provider-label{font-size:10px;text-transform:uppercase;letter-spacing:.08em;color:var(--text-muted);font-weight:600;padding:4px 12px 6px;display:flex;align-items:center;gap:6px}.provider-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.model-item{display:flex;align-items:center;gap:10px;padding:9px 12px;border-radius:var(--radius-sm);font-size:12.5px;font-weight:500;color:var(--text-secondary);cursor:pointer;transition:all var(--transition);border:1px solid transparent}.model-item:hover{background:var(--bg-surface);color:var(--text-primary);border-color:var(--border)}.model-item.active{background:var(--accent-dim);color:var(--accent);border-color:var(--border-accent);box-shadow:var(--accent-glow)}.model-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.model-info{display:flex;flex-direction:column;min-width:0}.model-name{flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.model-item .provider{font-size:10px;color:var(--text-muted);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stats-panel{padding:14px;background:var(--bg-surface);border:1px solid var(--border);border-radius:var(--radius-md);display:flex;flex-direction:column;gap:10px}.stat-row{display:flex;align-items:center;justify-content:space-between;font-size:12px}.stat-row .label,.stat-icon-label{display:flex;align-items:center;gap:8px;color:var(--text-secondary)}.stat-row .label svg,.stat-icon-label svg{opacity:.5}.stat-row .value{color:var(--text-primary);font-weight:600;font-variant-numeric:tabular-nums}.sidebar-bottom{margin-top:auto;padding-top:12px;border-top:1px solid var(--border)}.btn-clear{width:100%;justify-content:center;margin-top:auto}.btn-clear:hover:not(:disabled){border-color:var(--danger-border)!important;color:var(--danger)!important;background:var(--danger-bg)!important}.chat-area{flex:1;display:flex;flex-direction:column;background:var(--bg-primary)}.messages{flex:1;overflow-y:auto;padding:24px;display:flex;flex-direction:column;gap:16px}.message{max-width:75%;padding:14px 18px;border-radius:var(--radius-lg);font-size:13.5px;line-height:1.7;white-space:pre-wrap;word-break:break-word;animation:messageIn .3s ease-out}@keyframes messageIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.message.user{align-self:flex-end;background:linear-gradient(135deg,#38bdf81f,#818cf81f);border:1px solid var(--border-accent);color:var(--text-primary);border-bottom-right-radius:4px}.message.assistant{align-self:flex-start;background:var(--bg-elevated);border:1px solid var(--border);border-bottom-left-radius:4px}.message.error{align-self:center;background:var(--danger-bg);border:1px solid var(--danger-border);color:var(--danger);font-size:13px;max-width:90%}.message .meta{margin-top:10px;font-size:11px;color:var(--text-muted);display:flex;gap:12px}.message.user .meta{color:#38bdf880}.thinking-dots{display:flex;gap:5px;padding:2px 0}.thinking-dots span{width:7px;height:7px;border-radius:50%;background:var(--text-muted);animation:bounce 1.4s ease-in-out infinite}.thinking-dots span:nth-child(2){animation-delay:.16s}.thinking-dots span:nth-child(3){animation-delay:.32s}@keyframes bounce{0%,60%,to{transform:translateY(0);opacity:.4}30%{transform:translateY(-6px);opacity:1}}.input-area{padding:16px 24px;background:var(--bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border-top:1px solid var(--border)}.input-row{display:flex;gap:12px;align-items:flex-end}.input-row textarea{flex:1;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-md);color:var(--text-primary);font-size:13.5px;font-family:inherit;resize:none;min-height:48px;max-height:200px;transition:border-color var(--transition)}.input-row textarea:focus{outline:none;border-color:var(--border-accent);box-shadow:var(--accent-glow)}.input-row textarea::placeholder{color:var(--text-muted)}.input-row button[type=submit]{padding:12px;width:48px;height:48px;background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-accent);border-radius:var(--radius-md);font-size:14px;cursor:pointer;transition:all var(--transition);display:flex;align-items:center;justify-content:center;flex-shrink:0}.input-row button[type=submit]:hover:not(:disabled){background:#38bdf826;box-shadow:var(--accent-glow-strong)}.input-row button[type=submit]:disabled{opacity:.3;cursor:not-allowed}.empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;flex:1;gap:12px;padding:40px}.empty-state .empty-icon{color:var(--accent);opacity:.3;margin-bottom:8px}.empty-state h2{font-size:18px;font-weight:700;background:var(--gradient-accent-text);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.empty-state p{font-size:13px;color:var(--text-muted)}.empty-state .empty-model{font-size:11px;color:var(--text-muted);opacity:.6;margin-top:4px;font-family:SF Mono,Fira Code,monospace}.spin{animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.admin-page{flex:1;padding:28px 36px;overflow-y:auto;background:var(--bg-primary)}.admin-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:24px}.admin-header h2{font-size:20px;font-weight:700;letter-spacing:-.02em;color:var(--text-primary)}.admin-error{padding:12px 16px;margin-bottom:16px;background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius-md);color:var(--danger);font-size:13px;font-weight:500}.admin-loading{text-align:center;padding:60px 0;color:var(--text-muted);font-size:13px}.admin-empty{text-align:center;padding:40px 0;color:var(--text-muted)}.stats-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:24px}.stat-card{padding:20px 22px;background:var(--bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius-lg);position:relative;overflow:hidden;transition:all var(--transition)}.stat-card:before{content:"";position:absolute;top:0;left:0;right:0;height:2px;background:var(--gradient-accent);opacity:.6}.stat-card:hover{border-color:var(--border-accent);box-shadow:var(--accent-glow)}.stat-value{font-size:30px;font-weight:800;color:var(--text-primary);line-height:1.2;letter-spacing:-.03em;font-variant-numeric:tabular-nums}.stat-value.stat-blocked{color:var(--danger)}.stat-label{font-size:11px;color:var(--text-muted);margin-top:6px;text-transform:uppercase;letter-spacing:.06em;font-weight:600}.admin-table-wrap{overflow-x:auto;background:var(--bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.admin-table{width:100%;border-collapse:collapse;font-size:13px}.admin-table thead{background:#ffffff05}.admin-table th{padding:12px 16px;text-align:left;font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted);border-bottom:1px solid var(--border);white-space:nowrap}.admin-table td{padding:12px 16px;border-bottom:1px solid var(--border-subtle);color:var(--text-secondary);transition:background var(--transition)}.admin-table tbody tr{transition:background var(--transition)}.admin-table tbody tr:hover{background:#38bdf805}.admin-table tbody tr:last-child td{border-bottom:none}.mono{font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:11.5px}.entity-badge{display:inline-block;padding:3px 10px;border-radius:4px;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-primary);font-size:11px;font-weight:600;letter-spacing:.02em}.action-badge{display:inline-block;padding:3px 12px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.action-mask{background:var(--warning-bg);color:var(--warning);border:1px solid var(--warning-border);box-shadow:0 0 12px #fbbf240f}.action-block{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border);box-shadow:0 0 12px #f871710f}.action-allow{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border);box-shadow:0 0 12px #34d3990f}.status-badge{display:inline-block;padding:3px 12px;border-radius:20px;font-size:10px;font-weight:700;letter-spacing:.04em;text-transform:uppercase}.status-success{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.status-blocked,.status-error{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.toggle-btn{padding:4px 12px;border:none;border-radius:20px;font-size:10px;font-weight:700;cursor:pointer;transition:all var(--transition);letter-spacing:.04em}.toggle-btn.on{background:var(--success-bg);color:var(--success);border:1px solid var(--success-border)}.toggle-btn.off{background:var(--bg-surface);color:var(--text-muted);border:1px solid var(--border)}.toggle-btn:hover{filter:brightness(1.2)}.btn{display:inline-flex;align-items:center;gap:6px;padding:8px 16px;border:none;border-radius:var(--radius-sm);font-size:12.5px;font-weight:600;cursor:pointer;transition:all var(--transition);font-family:inherit}.btn:disabled{opacity:.4;cursor:not-allowed}.btn-primary{background:var(--accent-dim);color:var(--accent);border:1px solid var(--border-accent)}.btn-primary:hover:not(:disabled){background:#38bdf826;box-shadow:var(--accent-glow)}.btn-secondary{background:var(--bg-surface);color:var(--text-secondary);border:1px solid var(--border)}.btn-secondary:hover:not(:disabled){border-color:var(--border-hover);color:var(--text-primary);background:var(--bg-glass-hover)}.btn-danger{background:var(--danger-bg);color:var(--danger);border:1px solid var(--danger-border)}.btn-danger:hover:not(:disabled){background:#f871711f;box-shadow:0 0 12px #f8717114}.btn-sm{padding:5px 10px;font-size:11.5px}.row-actions{display:flex;gap:6px}.btn-icon{display:flex;align-items:center;justify-content:center;padding:6px;background:transparent;border:none;color:var(--text-muted);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition)}.btn-icon:hover{color:var(--text-primary);background:var(--bg-surface)}.btn-icon-action{display:flex;align-items:center;justify-content:center;padding:6px 8px;background:var(--bg-surface);border:1px solid var(--border);color:var(--text-secondary);cursor:pointer;border-radius:var(--radius-sm);transition:all var(--transition)}.btn-icon-action:hover{color:var(--text-primary);border-color:var(--border-hover);background:var(--bg-glass-hover)}.btn-icon-action.btn-danger{color:var(--text-secondary)}.btn-icon-action.btn-danger:hover{color:var(--danger);border-color:var(--danger-border);background:var(--danger-bg)}.admin-form{margin-bottom:24px;padding:24px;background:var(--bg-glass);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);border:1px solid var(--border);border-radius:var(--radius-lg);box-shadow:var(--shadow-md)}.form-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:18px}.form-header h3{font-size:15px;font-weight:700;color:var(--text-primary)}.admin-form h3{font-size:15px;font-weight:700;color:var(--text-primary);margin-bottom:18px}.form-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:14px;margin-bottom:14px}.form-grid label,.form-checkbox{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--text-secondary);font-weight:600;text-transform:uppercase;letter-spacing:.04em}.form-checkbox{flex-direction:row;align-items:center;gap:8px;margin-bottom:14px;text-transform:none}.form-grid select,.form-grid input{padding:9px 12px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:13px;font-family:inherit;transition:all var(--transition)}.form-grid select:focus,.form-grid input:focus{outline:none;border-color:var(--border-accent);box-shadow:var(--accent-glow)}.form-actions{display:flex;gap:8px}.category-cell{font-size:11px;color:var(--text-muted);font-weight:500}.pagination{display:flex;align-items:center;justify-content:center;gap:16px;margin-top:18px;padding:14px 0}.page-info{font-size:12px;color:var(--text-muted);font-variant-numeric:tabular-nums}.login-page{flex:1;display:flex;align-items:center;justify-content:center;background:var(--bg-primary);position:relative}.login-page:before{content:"";position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:500px;height:500px;background:radial-gradient(circle,rgba(56,189,248,.04) 0%,transparent 70%);pointer-events:none}.login-form{width:100%;max-width:400px;padding:44px 40px;background:var(--bg-glass);-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border:1px solid var(--border);border-radius:var(--radius-xl);box-shadow:var(--shadow-lg),var(--shadow-glow);position:relative;text-align:center}.login-icon{color:var(--accent);margin-bottom:16px;opacity:.8}.login-form h2{font-size:20px;font-weight:700;color:var(--text-primary);margin-bottom:4px;letter-spacing:-.02em}.login-subtitle{font-size:13px;color:var(--text-muted);margin-bottom:28px}.login-error{padding:10px 14px;margin-bottom:16px;background:var(--danger-bg);border:1px solid var(--danger-border);border-radius:var(--radius-sm);color:var(--danger);font-size:13px;text-align:left}.login-form label{display:flex;flex-direction:column;gap:6px;font-size:11px;color:var(--text-secondary);font-weight:600;margin-bottom:16px;text-align:left;text-transform:uppercase;letter-spacing:.04em}.login-form input{padding:11px 14px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);color:var(--text-primary);font-size:14px;font-family:inherit;transition:all var(--transition)}.login-form input:focus{outline:none;border-color:var(--border-accent);box-shadow:var(--accent-glow)}.login-btn{width:100%;padding:12px;font-size:13px;font-weight:700;margin-top:8px;background:linear-gradient(135deg,#38bdf826,#818cf826);border:1px solid var(--border-accent);color:var(--accent);border-radius:var(--radius-sm);cursor:pointer;transition:all var(--transition);font-family:inherit;letter-spacing:.02em}.login-btn:hover:not(:disabled){background:linear-gradient(135deg,#38bdf833,#818cf833);box-shadow:var(--accent-glow-strong)}.login-btn:disabled{opacity:.4;cursor:not-allowed}.admin-table tbody tr.row-expanded{background:#38bdf808}.admin-table tbody tr.row-expanded td{border-bottom-color:transparent}.audit-detail-row td{padding:0 16px 16px!important;background:#38bdf805;border-bottom:1px solid var(--border)!important}.audit-detail{display:flex;flex-direction:column;gap:12px}.audit-detail-section{display:flex;flex-direction:column;gap:6px}.audit-detail-label{font-size:10px;font-weight:700;text-transform:uppercase;letter-spacing:.06em;color:var(--text-muted)}.audit-detail-body{padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:var(--radius-sm);font-family:SF Mono,Fira Code,Cascadia Code,monospace;font-size:12px;line-height:1.6;color:var(--text-secondary);white-space:pre-wrap;word-break:break-word;max-height:300px;overflow-y:auto;margin:0}
