| |
| |
| |
| |
|
|
| |
| |
| |
|
|
| .background-effects { |
| position: fixed; |
| inset: 0; |
| pointer-events: none; |
| z-index: 0; |
| overflow: hidden; |
| } |
|
|
| .gradient-orb { |
| position: absolute; |
| border-radius: 50%; |
| filter: blur(100px); |
| opacity: 0.25; |
| animation: float 25s ease-in-out infinite; |
| } |
|
|
| .orb-1 { |
| width: 600px; |
| height: 600px; |
| background: radial-gradient(circle, rgba(139, 92, 246, 0.5) 0%, transparent 70%); |
| top: -300px; |
| left: -200px; |
| animation-delay: 0s; |
| } |
|
|
| .orb-2 { |
| width: 500px; |
| height: 500px; |
| background: radial-gradient(circle, rgba(59, 130, 246, 0.4) 0%, transparent 70%); |
| bottom: -250px; |
| right: -150px; |
| animation-delay: 8s; |
| } |
|
|
| .orb-3 { |
| width: 400px; |
| height: 400px; |
| background: radial-gradient(circle, rgba(34, 211, 238, 0.35) 0%, transparent 70%); |
| top: 40%; |
| left: 60%; |
| transform: translate(-50%, -50%); |
| animation-delay: 16s; |
| } |
|
|
| @keyframes float { |
| 0%, 100% { transform: translate(0, 0) scale(1); } |
| 33% { transform: translate(40px, -40px) scale(1.05); } |
| 66% { transform: translate(-30px, 30px) scale(0.95); } |
| } |
|
|
| |
| |
| |
|
|
| .page-header.glass-panel { |
| display: flex; |
| justify-content: space-between; |
| align-items: center; |
| padding: var(--space-6); |
| background: rgba(17, 24, 39, 0.7); |
| backdrop-filter: blur(20px); |
| -webkit-backdrop-filter: blur(20px); |
| border: 1px solid rgba(255, 255, 255, 0.1); |
| border-radius: var(--radius-xl); |
| margin-bottom: var(--space-6); |
| position: relative; |
| overflow: hidden; |
| } |
|
|
| .page-header.glass-panel::before { |
| content: ''; |
| position: absolute; |
| top: 0; |
| left: 0; |
| right: 0; |
| height: 3px; |
| background: linear-gradient(90deg, #8b5cf6, #3b82f6, #22d3ee); |
| } |
|
|
| .page-title { |
| display: flex; |
| align-items: center; |
| gap: var(--space-4); |
| } |
|
|
| .title-icon { |
| width: 60px; |
| height: 60px; |
| background: linear-gradient(135deg, #8b5cf6 0%, #3b82f6 100%); |
| border-radius: var(--radius-lg); |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| color: white; |
| box-shadow: 0 4px 20px rgba(139, 92, 246, 0.4); |
| animation: pulse-glow 3s ease-in-out infinite; |
| } |
|
|
| @keyframes pulse-glow { |
| 0%, 100% { box-shadow: 0 4px 20px rgba(139, 92, 246, 0.4); } |
| 50% { box-shadow: 0 4px 30px rgba(139, 92, 246, 0.6); } |
| } |
|
|
| .title-content h1 { |
| font-family: 'Space Grotesk', sans-serif; |
| font-size: var(--font-size-2xl); |
| font-weight: 700; |
| background: linear-gradient(135deg, #fff 0%, #a5b4fc 100%); |
| -webkit-background-clip: text; |
| -webkit-text-fill-color: transparent; |
| background-clip: text; |
| margin: 0; |
| } |
|
|
| .page-subtitle { |
| font-size: var(--font-size-sm); |
| color: var(--text-muted); |
| margin-top: var(--space-1); |
| } |
|
|
| .page-actions { |
| display: flex; |
| align-items: center; |
| gap: var(--space-4); |
| } |
|
|
| .btn-gradient { |
| display: inline-flex; |
| align-items: center; |
| gap: var(--space-2); |
| padding: var(--space-3) var(--space-5); |
| background: linear-gradient(135deg, #8b5cf6 0%, #3b82f6 100%); |
| color: white; |
| border: none; |
| border-radius: var(--radius-md); |
| font-weight: 600; |
| font-size: var(--font-size-sm); |
| cursor: pointer; |
| transition: all 0.3s ease; |
| box-shadow: 0 4px 15px rgba(139, 92, 246, 0.3); |
| } |
|
|
| .btn-gradient:hover { |
| transform: translateY(-2px); |
| box-shadow: 0 6px 25px rgba(139, 92, 246, 0.5); |
| } |
|
|
| .btn-gradient.large { |
| padding: var(--space-4) var(--space-6); |
| font-size: var(--font-size-base); |
| } |
|
|
| .btn-secondary { |
| display: inline-flex; |
| align-items: center; |
| gap: var(--space-2); |
| padding: var(--space-3) var(--space-5); |
| background: rgba(255, 255, 255, 0.1); |
| color: var(--text-secondary); |
| border: 1px solid rgba(255, 255, 255, 0.15); |
| border-radius: var(--radius-md); |
| font-weight: 600; |
| font-size: var(--font-size-sm); |
| cursor: pointer; |
| transition: all 0.3s ease; |
| } |
|
|
| .btn-secondary:hover { |
| background: rgba(255, 255, 255, 0.15); |
| border-color: rgba(255, 255, 255, 0.25); |
| } |
|
|
| .last-update { |
| font-size: var(--font-size-xs); |
| color: var(--text-muted); |
| padding: var(--space-2) var(--space-3); |
| background: rgba(255, 255, 255, 0.05); |
| border-radius: var(--radius-sm); |
| } |
|
|
| |
| |
| |
|
|
| .stats-grid { |
| display: grid; |
| grid-template-columns: repeat(4, 1fr); |
| gap: var(--space-4); |
| margin-bottom: var(--space-6); |
| } |
|
|
| .stat-card.glass-card { |
| display: flex; |
| align-items: flex-start; |
| gap: var(--space-4); |
| padding: var(--space-5); |
| background: rgba(17, 24, 39, 0.6); |
| backdrop-filter: blur(15px); |
| -webkit-backdrop-filter: blur(15px); |
| border: 1px solid rgba(255, 255, 255, 0.08); |
| border-radius: var(--radius-xl); |
| transition: all 0.3s ease; |
| } |
|
|
| .stat-card.glass-card:hover { |
| transform: translateY(-4px); |
| border-color: rgba(255, 255, 255, 0.15); |
| box-shadow: 0 10px 40px rgba(0, 0, 0, 0.3); |
| } |
|
|
| .stat-icon { |
| width: 50px; |
| height: 50px; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| border-radius: var(--radius-lg); |
| flex-shrink: 0; |
| } |
|
|
| .stat-icon.models-icon { |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(139, 92, 246, 0.1) 100%); |
| color: #a78bfa; |
| } |
|
|
| .stat-icon.success-icon { |
| background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(34, 197, 94, 0.1) 100%); |
| color: #4ade80; |
| } |
|
|
| .stat-icon.warning-icon { |
| background: linear-gradient(135deg, rgba(245, 158, 11, 0.2) 0%, rgba(245, 158, 11, 0.1) 100%); |
| color: #fbbf24; |
| } |
|
|
| .stat-icon.info-icon { |
| background: linear-gradient(135deg, rgba(59, 130, 246, 0.2) 0%, rgba(59, 130, 246, 0.1) 100%); |
| color: #60a5fa; |
| } |
|
|
| .stat-content { |
| flex: 1; |
| min-width: 0; |
| } |
|
|
| .stat-value { |
| font-family: 'Space Grotesk', sans-serif; |
| font-size: var(--font-size-2xl); |
| font-weight: 700; |
| color: var(--text-strong); |
| line-height: 1; |
| margin-bottom: var(--space-1); |
| } |
|
|
| .stat-label { |
| font-size: var(--font-size-sm); |
| color: var(--text-secondary); |
| margin-bottom: var(--space-2); |
| } |
|
|
| .stat-trend { |
| font-size: var(--font-size-xs); |
| padding: var(--space-1) var(--space-2); |
| border-radius: var(--radius-xs); |
| display: inline-block; |
| } |
|
|
| .stat-trend.success { |
| background: rgba(34, 197, 94, 0.15); |
| color: #4ade80; |
| } |
|
|
| .stat-trend.warning { |
| background: rgba(245, 158, 11, 0.15); |
| color: #fbbf24; |
| } |
|
|
| .stat-trend.info { |
| background: rgba(59, 130, 246, 0.15); |
| color: #60a5fa; |
| } |
|
|
| .stat-trend.neutral { |
| background: rgba(148, 163, 184, 0.15); |
| color: #94a3b8; |
| } |
|
|
| |
| |
| |
|
|
| .tabs-container.glass-panel { |
| background: rgba(17, 24, 39, 0.6); |
| backdrop-filter: blur(15px); |
| border: 1px solid rgba(255, 255, 255, 0.08); |
| border-radius: var(--radius-xl); |
| padding: var(--space-2); |
| margin-bottom: var(--space-6); |
| } |
|
|
| .tabs { |
| display: flex; |
| gap: var(--space-2); |
| } |
|
|
| .tab-btn { |
| display: flex; |
| align-items: center; |
| gap: var(--space-2); |
| padding: var(--space-3) var(--space-5); |
| background: transparent; |
| color: var(--text-muted); |
| border: none; |
| border-radius: var(--radius-md); |
| font-weight: 600; |
| font-size: var(--font-size-sm); |
| cursor: pointer; |
| transition: all 0.3s ease; |
| } |
|
|
| .tab-btn:hover { |
| background: rgba(255, 255, 255, 0.05); |
| color: var(--text-secondary); |
| } |
|
|
| .tab-btn.active { |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.3) 0%, rgba(59, 130, 246, 0.3) 100%); |
| color: white; |
| box-shadow: 0 4px 15px rgba(139, 92, 246, 0.2); |
| } |
|
|
| .tab-content { |
| display: none; |
| } |
|
|
| .tab-content.active { |
| display: block; |
| animation: fadeIn 0.3s ease; |
| } |
|
|
| @keyframes fadeIn { |
| from { opacity: 0; transform: translateY(10px); } |
| to { opacity: 1; transform: translateY(0); } |
| } |
|
|
| |
| |
| |
|
|
| .section-header { |
| display: flex; |
| justify-content: space-between; |
| align-items: center; |
| margin-bottom: var(--space-5); |
| } |
|
|
| .section-header h2 { |
| font-family: 'Space Grotesk', sans-serif; |
| font-size: var(--font-size-xl); |
| font-weight: 700; |
| color: var(--text-strong); |
| margin: 0; |
| } |
|
|
| .filter-controls { |
| display: flex; |
| gap: var(--space-3); |
| } |
|
|
| .select-modern { |
| padding: var(--space-2) var(--space-4); |
| padding-right: var(--space-8); |
| background: rgba(17, 24, 39, 0.8); |
| border: 1px solid rgba(255, 255, 255, 0.1); |
| border-radius: var(--radius-md); |
| color: var(--text-secondary); |
| font-size: var(--font-size-sm); |
| cursor: pointer; |
| appearance: none; |
| background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' stroke-width='2'%3E%3Cpath d='m6 9 6 6 6-6'/%3E%3C/svg%3E"); |
| background-repeat: no-repeat; |
| background-position: right 12px center; |
| transition: all 0.3s ease; |
| } |
|
|
| .select-modern:hover { |
| border-color: rgba(139, 92, 246, 0.5); |
| } |
|
|
| .select-modern:focus { |
| outline: none; |
| border-color: #8b5cf6; |
| box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.2); |
| } |
|
|
| .select-modern.large { |
| padding: var(--space-3) var(--space-5); |
| padding-right: var(--space-10); |
| font-size: var(--font-size-base); |
| } |
|
|
| |
| |
| |
|
|
| .models-grid { |
| display: grid; |
| |
| grid-template-columns: repeat(auto-fill, minmax(min(100%, 380px), 1fr)); |
| gap: var(--space-5); |
| |
| width: 100%; |
| max-width: 100%; |
| } |
|
|
| .model-card { |
| background: rgba(17, 24, 39, 0.7); |
| backdrop-filter: blur(15px); |
| -webkit-backdrop-filter: blur(15px); |
| border: 1px solid rgba(255, 255, 255, 0.08); |
| border-radius: var(--radius-xl); |
| overflow: hidden; |
| transition: all 0.4s cubic-bezier(0.4, 0, 0.2, 1); |
| position: relative; |
| display: flex; |
| |
| min-height: 320px; |
| max-width: 100%; |
| flex-direction: column; |
| } |
|
|
| .model-card::before { |
| content: ''; |
| position: absolute; |
| top: 0; |
| left: 0; |
| right: 0; |
| height: 3px; |
| background: linear-gradient(90deg, #8b5cf6, #3b82f6); |
| transform: scaleX(0); |
| transform-origin: left; |
| transition: transform 0.4s ease; |
| } |
|
|
| .model-card:hover { |
| transform: translateY(-6px); |
| border-color: rgba(139, 92, 246, 0.3); |
| box-shadow: 0 20px 50px rgba(0, 0, 0, 0.4); |
| } |
|
|
| .model-card:hover::before { |
| transform: scaleX(1); |
| } |
|
|
| .model-card.loaded::before { |
| background: linear-gradient(90deg, #22c55e, #10b981); |
| transform: scaleX(1); |
| } |
|
|
| .model-card.failed::before { |
| background: linear-gradient(90deg, #ef4444, #f97316); |
| transform: scaleX(1); |
| } |
|
|
| |
| .model-details { |
| padding: var(--space-4); |
| flex: 1; |
| } |
|
|
| .detail-row { |
| display: flex; |
| gap: var(--space-4); |
| margin-bottom: var(--space-3); |
| } |
|
|
| .detail-item { |
| flex: 1; |
| } |
|
|
| .detail-label { |
| display: block; |
| font-size: var(--font-size-xs); |
| color: var(--text-muted); |
| text-transform: uppercase; |
| letter-spacing: 0.05em; |
| margin-bottom: var(--space-1); |
| } |
|
|
| .detail-value { |
| display: block; |
| font-size: var(--font-size-sm); |
| color: var(--text-strong); |
| font-weight: var(--font-weight-semibold); |
| } |
|
|
| .detail-value.status-success { |
| color: #4ade80; |
| } |
|
|
| .detail-value.status-warning { |
| color: #fbbf24; |
| } |
|
|
| .detail-value.status-info { |
| color: #60a5fa; |
| } |
|
|
| .model-description { |
| padding: var(--space-4); |
| border-top: 1px solid rgba(255, 255, 255, 0.05); |
| font-size: var(--font-size-sm); |
| color: var(--text-secondary); |
| line-height: 1.5; |
| } |
|
|
| .model-actions { |
| padding: var(--space-4); |
| border-top: 1px solid rgba(255, 255, 255, 0.05); |
| display: flex; |
| gap: var(--space-2); |
| background: rgba(0, 0, 0, 0.15); |
| } |
|
|
| .model-actions .btn { |
| flex: 1; |
| display: inline-flex; |
| align-items: center; |
| justify-content: center; |
| gap: var(--space-2); |
| padding: var(--space-2) var(--space-3); |
| background: rgba(255, 255, 255, 0.05); |
| border: 1px solid rgba(255, 255, 255, 0.1); |
| border-radius: var(--radius-md); |
| color: var(--text-secondary); |
| font-size: var(--font-size-xs); |
| font-weight: 600; |
| cursor: pointer; |
| transition: all 0.3s ease; |
| } |
|
|
| .model-actions .btn:hover:not(:disabled) { |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.3) 0%, rgba(59, 130, 246, 0.3) 100%); |
| border-color: rgba(139, 92, 246, 0.5); |
| color: white; |
| } |
|
|
| .model-actions .btn:disabled { |
| opacity: 0.5; |
| cursor: not-allowed; |
| } |
|
|
| .model-actions .btn-primary { |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.3) 0%, rgba(59, 130, 246, 0.3) 100%); |
| border-color: rgba(139, 92, 246, 0.5); |
| color: white; |
| } |
|
|
| .model-actions .btn-secondary { |
| background: rgba(255, 255, 255, 0.05); |
| border-color: rgba(255, 255, 255, 0.1); |
| color: var(--text-secondary); |
| } |
|
|
| .model-header { |
| display: flex; |
| align-items: center; |
| gap: var(--space-4); |
| padding: var(--space-5); |
| background: rgba(0, 0, 0, 0.2); |
| border-bottom: 1px solid rgba(255, 255, 255, 0.05); |
| } |
|
|
| .model-icon { |
| width: 48px; |
| height: 48px; |
| display: flex; |
| align-items: center; |
| justify-content: center; |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(59, 130, 246, 0.2) 100%); |
| border-radius: var(--radius-lg); |
| color: #a78bfa; |
| transition: all 0.3s ease; |
| } |
|
|
| .model-card:hover .model-icon { |
| transform: scale(1.1) rotate(5deg); |
| } |
|
|
| .model-info { |
| flex: 1; |
| min-width: 0; |
| } |
|
|
| .model-name { |
| font-family: 'Space Grotesk', sans-serif; |
| font-size: var(--font-size-base); |
| font-weight: 700; |
| color: var(--text-strong); |
| margin: 0 0 var(--space-1) 0; |
| white-space: nowrap; |
| overflow: hidden; |
| text-overflow: ellipsis; |
| } |
|
|
| .model-type { |
| font-family: 'JetBrains Mono', monospace; |
| font-size: var(--font-size-xs); |
| color: var(--text-muted); |
| text-transform: uppercase; |
| letter-spacing: 0.5px; |
| } |
|
|
| .model-status { |
| padding: var(--space-1) var(--space-3); |
| border-radius: var(--radius-full); |
| font-size: var(--font-size-xs); |
| font-weight: 600; |
| text-transform: uppercase; |
| letter-spacing: 0.5px; |
| } |
|
|
| .model-status.loaded { |
| background: rgba(34, 197, 94, 0.2); |
| color: #4ade80; |
| } |
|
|
| .model-status.available { |
| background: rgba(59, 130, 246, 0.2); |
| color: #60a5fa; |
| } |
|
|
| .model-status.failed { |
| background: rgba(239, 68, 68, 0.2); |
| color: #f87171; |
| } |
|
|
| .model-status.cooldown { |
| background: rgba(245, 158, 11, 0.2); |
| color: #fbbf24; |
| } |
|
|
| .model-body { |
| padding: var(--space-5); |
| } |
|
|
| .model-id { |
| font-family: 'JetBrains Mono', monospace; |
| font-size: var(--font-size-xs); |
| color: var(--text-muted); |
| background: rgba(0, 0, 0, 0.3); |
| padding: var(--space-2) var(--space-3); |
| border-radius: var(--radius-sm); |
| margin-bottom: var(--space-4); |
| word-break: break-all; |
| } |
|
|
| .model-meta { |
| display: flex; |
| flex-wrap: wrap; |
| gap: var(--space-3); |
| } |
|
|
| .meta-badge { |
| display: inline-flex; |
| align-items: center; |
| gap: var(--space-1); |
| padding: var(--space-1) var(--space-3); |
| background: rgba(255, 255, 255, 0.05); |
| border-radius: var(--radius-sm); |
| font-size: var(--font-size-xs); |
| color: var(--text-muted); |
| } |
|
|
| .meta-badge svg { |
| width: 12px; |
| height: 12px; |
| } |
|
|
| .model-footer { |
| padding: var(--space-4) var(--space-5); |
| background: rgba(0, 0, 0, 0.15); |
| border-top: 1px solid rgba(255, 255, 255, 0.05); |
| display: flex; |
| gap: var(--space-2); |
| } |
|
|
| .model-footer .btn { |
| flex: 1; |
| display: inline-flex; |
| align-items: center; |
| justify-content: center; |
| gap: var(--space-2); |
| padding: var(--space-2) var(--space-3); |
| background: rgba(255, 255, 255, 0.05); |
| border: 1px solid rgba(255, 255, 255, 0.1); |
| border-radius: var(--radius-md); |
| color: var(--text-secondary); |
| font-size: var(--font-size-xs); |
| font-weight: 600; |
| cursor: pointer; |
| transition: all 0.3s ease; |
| } |
|
|
| .model-footer .btn:hover { |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.3) 0%, rgba(59, 130, 246, 0.3) 100%); |
| border-color: rgba(139, 92, 246, 0.5); |
| color: white; |
| } |
|
|
| .model-footer .btn.reinit { |
| background: rgba(245, 158, 11, 0.1); |
| border-color: rgba(245, 158, 11, 0.3); |
| color: #fbbf24; |
| } |
|
|
| .model-footer .btn.reinit:hover { |
| background: rgba(245, 158, 11, 0.2); |
| } |
|
|
| |
| |
| |
|
|
| .test-panel.glass-panel, |
| .health-panel.glass-panel, |
| .catalog-panel.glass-panel { |
| background: rgba(17, 24, 39, 0.7); |
| backdrop-filter: blur(15px); |
| border: 1px solid rgba(255, 255, 255, 0.08); |
| border-radius: var(--radius-xl); |
| padding: var(--space-6); |
| } |
|
|
| .test-header, |
| .health-header, |
| .catalog-header { |
| margin-bottom: var(--space-6); |
| } |
|
|
| .test-header h2, |
| .health-header h2, |
| .catalog-header h2 { |
| font-family: 'Space Grotesk', sans-serif; |
| font-size: var(--font-size-xl); |
| font-weight: 700; |
| color: var(--text-strong); |
| margin: 0 0 var(--space-2) 0; |
| } |
|
|
| .test-header p, |
| .health-header p, |
| .catalog-header p { |
| color: var(--text-muted); |
| font-size: var(--font-size-sm); |
| margin: 0; |
| } |
|
|
| .health-header { |
| display: flex; |
| justify-content: space-between; |
| align-items: flex-start; |
| flex-wrap: wrap; |
| gap: var(--space-4); |
| } |
|
|
| .test-form { |
| max-width: 800px; |
| } |
|
|
| .form-group { |
| margin-bottom: var(--space-5); |
| } |
|
|
| .form-label { |
| display: block; |
| font-weight: 600; |
| font-size: var(--font-size-sm); |
| color: var(--text-secondary); |
| margin-bottom: var(--space-2); |
| } |
|
|
| .textarea-modern { |
| width: 100%; |
| padding: var(--space-4); |
| background: rgba(0, 0, 0, 0.3); |
| border: 1px solid rgba(255, 255, 255, 0.1); |
| border-radius: var(--radius-md); |
| color: var(--text-strong); |
| font-family: inherit; |
| font-size: var(--font-size-base); |
| resize: vertical; |
| transition: all 0.3s ease; |
| } |
|
|
| .textarea-modern:focus { |
| outline: none; |
| border-color: #8b5cf6; |
| box-shadow: 0 0 0 3px rgba(139, 92, 246, 0.2); |
| } |
|
|
| .test-actions { |
| display: flex; |
| gap: var(--space-3); |
| margin-bottom: var(--space-6); |
| } |
|
|
| .example-texts { |
| padding: var(--space-4); |
| background: rgba(0, 0, 0, 0.2); |
| border-radius: var(--radius-lg); |
| } |
|
|
| .example-label { |
| font-size: var(--font-size-sm); |
| color: var(--text-muted); |
| margin-bottom: var(--space-3); |
| } |
|
|
| .example-buttons { |
| display: flex; |
| flex-wrap: wrap; |
| gap: var(--space-2); |
| } |
|
|
| .example-btn { |
| padding: var(--space-2) var(--space-4); |
| background: rgba(255, 255, 255, 0.05); |
| border: 1px solid rgba(255, 255, 255, 0.1); |
| border-radius: var(--radius-md); |
| color: var(--text-secondary); |
| font-size: var(--font-size-sm); |
| cursor: pointer; |
| transition: all 0.3s ease; |
| } |
|
|
| .example-btn:hover { |
| background: rgba(139, 92, 246, 0.2); |
| border-color: rgba(139, 92, 246, 0.4); |
| color: white; |
| } |
|
|
| |
| .test-result { |
| margin-top: var(--space-6); |
| padding: var(--space-6); |
| background: linear-gradient(180deg, rgba(2, 6, 23, 0.55), rgba(0, 0, 0, 0.35)); |
| border: 1px solid rgba(255, 255, 255, 0.12); |
| border-radius: var(--radius-xl); |
| box-shadow: 0 18px 60px rgba(0, 0, 0, 0.35); |
| position: relative; |
| overflow: hidden; |
| animation: fadeIn 0.4s ease; |
| } |
|
|
| .test-result::before { |
| content: ''; |
| position: absolute; |
| inset: 0; |
| pointer-events: none; |
| background: radial-gradient(900px 220px at 20% 0%, rgba(139, 92, 246, 0.18), transparent 60%), |
| radial-gradient(900px 220px at 80% 0%, rgba(34, 211, 238, 0.14), transparent 60%); |
| opacity: 0.9; |
| } |
|
|
| .test-result.hidden { |
| display: none; |
| } |
|
|
| .result-header { |
| display: flex; |
| justify-content: space-between; |
| align-items: center; |
| margin-bottom: var(--space-4); |
| position: relative; |
| z-index: 1; |
| } |
|
|
| .result-header h3 { |
| font-size: var(--font-size-lg); |
| font-weight: 700; |
| color: var(--text-strong); |
| margin: 0; |
| } |
|
|
| .result-time { |
| font-size: var(--font-size-xs); |
| color: var(--text-muted); |
| padding: 6px 10px; |
| border-radius: var(--radius-full); |
| background: rgba(255, 255, 255, 0.06); |
| border: 1px solid rgba(255, 255, 255, 0.10); |
| } |
|
|
| .result-body { |
| display: grid; |
| grid-template-columns: minmax(260px, 360px) 1fr; |
| gap: var(--space-5); |
| position: relative; |
| z-index: 1; |
| } |
|
|
| .sentiment-display { |
| --accent-rgb: 96 165 250; |
| text-align: left; |
| padding: var(--space-6); |
| background: linear-gradient(135deg, rgba(var(--accent-rgb) / 0.14) 0%, rgba(255, 255, 255, 0.04) 65%); |
| border: 1px solid rgba(255, 255, 255, 0.10); |
| border-radius: var(--radius-xl); |
| display: grid; |
| grid-template-columns: 76px 1fr; |
| grid-template-rows: auto auto; |
| column-gap: var(--space-4); |
| row-gap: var(--space-2); |
| } |
|
|
| .sentiment-display[data-sentiment="bullish"], |
| .sentiment-display[data-sentiment="positive"], |
| .sentiment-display[data-sentiment="buy"] { --accent-rgb: 34 197 94; } |
|
|
| .sentiment-display[data-sentiment="bearish"], |
| .sentiment-display[data-sentiment="negative"], |
| .sentiment-display[data-sentiment="sell"] { --accent-rgb: 239 68 68; } |
|
|
| .sentiment-display[data-sentiment="neutral"], |
| .sentiment-display[data-sentiment="hold"] { --accent-rgb: 59 130 246; } |
|
|
| .sentiment-display[data-sentiment="unknown"] { --accent-rgb: 148 163 184; } |
|
|
| .sentiment-emoji { |
| grid-row: 1 / span 2; |
| grid-column: 1; |
| width: 76px; |
| height: 76px; |
| display: grid; |
| place-items: center; |
| font-size: 42px; |
| border-radius: 18px; |
| background: rgba(var(--accent-rgb) / 0.16); |
| border: 1px solid rgba(var(--accent-rgb) / 0.28); |
| box-shadow: 0 10px 30px rgba(0, 0, 0, 0.25); |
| } |
|
|
| .sentiment-label { |
| grid-column: 2; |
| grid-row: 1; |
| font-family: 'Space Grotesk', sans-serif; |
| font-size: clamp(22px, 2.2vw, 30px); |
| font-weight: 700; |
| text-transform: uppercase; |
| letter-spacing: 0.08em; |
| margin: 0; |
| line-height: 1.1; |
| color: rgb(var(--accent-rgb)); |
| } |
|
|
| .sentiment-label.bullish, |
| .sentiment-label.positive, |
| .sentiment-label.buy { color: rgb(34, 197, 94); } |
|
|
| .sentiment-label.bearish, |
| .sentiment-label.negative, |
| .sentiment-label.sell { color: rgb(239, 68, 68); } |
|
|
| .sentiment-label.neutral, |
| .sentiment-label.hold { color: rgb(59, 130, 246); } |
|
|
| .sentiment-label.unknown { color: rgb(148, 163, 184); } |
|
|
| .sentiment-confidence { |
| grid-column: 2; |
| grid-row: 2; |
| font-size: var(--font-size-sm); |
| color: rgba(226, 232, 240, 0.85); |
| padding: 10px 12px; |
| border-radius: var(--radius-lg); |
| border: 1px solid rgba(255, 255, 255, 0.10); |
| background: |
| linear-gradient( |
| 90deg, |
| rgba(var(--accent-rgb) / 0.25) 0 var(--confidence, 0%), |
| rgba(255, 255, 255, 0.06) var(--confidence, 0%) 100% |
| ); |
| box-shadow: inset 0 1px 0 rgba(255, 255, 255, 0.08); |
| } |
|
|
| .result-details { |
| background: rgba(0, 0, 0, 0.38); |
| border: 1px solid rgba(255, 255, 255, 0.10); |
| border-radius: var(--radius-md); |
| padding: var(--space-4); |
| overflow: auto; |
| max-height: 300px; |
| } |
|
|
| .result-json { |
| font-family: 'JetBrains Mono', monospace; |
| font-size: 12px; |
| color: rgba(226, 232, 240, 0.92); |
| white-space: pre-wrap; |
| margin: 0; |
| line-height: 1.55; |
| } |
|
|
| @media (max-width: 900px) { |
| .result-body { |
| grid-template-columns: 1fr; |
| } |
| .sentiment-display { |
| grid-template-columns: 64px 1fr; |
| padding: var(--space-5); |
| } |
| .sentiment-emoji { |
| width: 64px; |
| height: 64px; |
| font-size: 36px; |
| border-radius: 16px; |
| } |
| } |
|
|
| |
| |
| |
|
|
| .health-grid { |
| display: grid; |
| grid-template-columns: repeat(auto-fill, minmax(350px, 1fr)); |
| gap: var(--space-4); |
| } |
|
|
| .health-card { |
| background: rgba(0, 0, 0, 0.3); |
| border: 1px solid rgba(255, 255, 255, 0.08); |
| border-radius: var(--radius-lg); |
| padding: var(--space-4); |
| transition: all 0.3s ease; |
| } |
|
|
| .health-card:hover { |
| border-color: rgba(255, 255, 255, 0.15); |
| } |
|
|
| .health-card.healthy { |
| border-left: 3px solid #4ade80; |
| } |
|
|
| .health-card.degraded { |
| border-left: 3px solid #fbbf24; |
| } |
|
|
| .health-card.unavailable { |
| border-left: 3px solid #f87171; |
| } |
|
|
| .health-card.unknown { |
| border-left: 3px solid #94a3b8; |
| } |
|
|
| .health-header-row { |
| display: flex; |
| justify-content: space-between; |
| align-items: flex-start; |
| margin-bottom: var(--space-3); |
| } |
|
|
| .health-model-name { |
| font-weight: 600; |
| color: var(--text-strong); |
| font-size: var(--font-size-sm); |
| } |
|
|
| .health-status-badge { |
| padding: var(--space-1) var(--space-2); |
| border-radius: var(--radius-sm); |
| font-size: var(--font-size-xs); |
| font-weight: 600; |
| text-transform: uppercase; |
| } |
|
|
| .health-status-badge.healthy { |
| background: rgba(34, 197, 94, 0.2); |
| color: #4ade80; |
| } |
|
|
| .health-status-badge.degraded { |
| background: rgba(245, 158, 11, 0.2); |
| color: #fbbf24; |
| } |
|
|
| .health-status-badge.unavailable { |
| background: rgba(239, 68, 68, 0.2); |
| color: #f87171; |
| } |
|
|
| .health-status-badge.unknown { |
| background: rgba(148, 163, 184, 0.2); |
| color: #94a3b8; |
| } |
|
|
| .health-stats { |
| display: grid; |
| grid-template-columns: repeat(3, 1fr); |
| gap: var(--space-2); |
| margin-bottom: var(--space-3); |
| } |
|
|
| .health-stat { |
| text-align: center; |
| padding: var(--space-2); |
| background: rgba(255, 255, 255, 0.03); |
| border-radius: var(--radius-sm); |
| } |
|
|
| .health-stat-value { |
| font-size: var(--font-size-lg); |
| font-weight: 700; |
| color: var(--text-strong); |
| } |
|
|
| .health-stat-label { |
| font-size: var(--font-size-xs); |
| color: var(--text-muted); |
| } |
|
|
| .health-error { |
| font-size: var(--font-size-xs); |
| color: #f87171; |
| background: rgba(239, 68, 68, 0.1); |
| padding: var(--space-2); |
| border-radius: var(--radius-sm); |
| margin-bottom: var(--space-3); |
| word-break: break-word; |
| } |
|
|
| .health-actions { |
| display: flex; |
| gap: var(--space-2); |
| } |
|
|
| .health-actions .btn { |
| flex: 1; |
| padding: var(--space-2); |
| background: rgba(255, 255, 255, 0.05); |
| border: 1px solid rgba(255, 255, 255, 0.1); |
| border-radius: var(--radius-sm); |
| color: var(--text-secondary); |
| font-size: var(--font-size-xs); |
| font-weight: 600; |
| cursor: pointer; |
| transition: all 0.3s ease; |
| } |
|
|
| .health-actions .btn:hover { |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.3) 0%, rgba(59, 130, 246, 0.3) 100%); |
| color: white; |
| } |
|
|
| |
| |
| |
|
|
| .catalog-grid { |
| display: grid; |
| grid-template-columns: repeat(auto-fill, minmax(450px, 1fr)); |
| gap: var(--space-5); |
| } |
|
|
| .catalog-category { |
| background: rgba(0, 0, 0, 0.25); |
| border: 1px solid rgba(255, 255, 255, 0.08); |
| border-radius: var(--radius-xl); |
| overflow: hidden; |
| } |
|
|
| .category-header { |
| display: flex; |
| align-items: center; |
| gap: var(--space-3); |
| padding: var(--space-4) var(--space-5); |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(59, 130, 246, 0.1) 100%); |
| border-bottom: 1px solid rgba(255, 255, 255, 0.08); |
| } |
|
|
| .category-header.crypto { |
| background: linear-gradient(135deg, rgba(245, 158, 11, 0.2) 0%, rgba(245, 158, 11, 0.1) 100%); |
| } |
|
|
| .category-header.financial { |
| background: linear-gradient(135deg, rgba(34, 197, 94, 0.2) 0%, rgba(34, 197, 94, 0.1) 100%); |
| } |
|
|
| .category-header.social { |
| background: linear-gradient(135deg, rgba(59, 130, 246, 0.2) 0%, rgba(59, 130, 246, 0.1) 100%); |
| } |
|
|
| .category-header.trading { |
| background: linear-gradient(135deg, rgba(239, 68, 68, 0.2) 0%, rgba(239, 68, 68, 0.1) 100%); |
| } |
|
|
| .category-header.generation { |
| background: linear-gradient(135deg, rgba(139, 92, 246, 0.2) 0%, rgba(139, 92, 246, 0.1) 100%); |
| } |
|
|
| .category-header.summarization { |
| background: linear-gradient(135deg, rgba(34, 211, 238, 0.2) 0%, rgba(34, 211, 238, 0.1) 100%); |
| } |
|
|
| .category-icon { |
| font-size: 24px; |
| } |
|
|
| .category-header h3 { |
| font-size: var(--font-size-base); |
| font-weight: 700; |
| color: var(--text-strong); |
| margin: 0; |
| } |
|
|
| .category-models { |
| padding: var(--space-4); |
| } |
|
|
| .catalog-model { |
| display: flex; |
| align-items: center; |
| justify-content: space-between; |
| padding: var(--space-3); |
| background: rgba(255, 255, 255, 0.03); |
| border-radius: var(--radius-md); |
| margin-bottom: var(--space-2); |
| transition: all 0.3s ease; |
| } |
|
|
| .catalog-model:last-child { |
| margin-bottom: 0; |
| } |
|
|
| .catalog-model:hover { |
| background: rgba(255, 255, 255, 0.08); |
| } |
|
|
| .catalog-model-name { |
| font-family: 'JetBrains Mono', monospace; |
| font-size: var(--font-size-xs); |
| color: var(--text-secondary); |
| word-break: break-all; |
| } |
|
|
| .catalog-model-badge { |
| padding: var(--space-1) var(--space-2); |
| border-radius: var(--radius-xs); |
| font-size: 10px; |
| font-weight: 600; |
| text-transform: uppercase; |
| white-space: nowrap; |
| } |
|
|
| .catalog-model-badge.public { |
| background: rgba(34, 197, 94, 0.2); |
| color: #4ade80; |
| } |
|
|
| .catalog-model-badge.auth { |
| background: rgba(245, 158, 11, 0.2); |
| color: #fbbf24; |
| } |
|
|
| |
| |
| |
|
|
| .loading-state { |
| grid-column: 1 / -1; |
| display: flex; |
| flex-direction: column; |
| align-items: center; |
| justify-content: center; |
| padding: var(--space-16); |
| text-align: center; |
| } |
|
|
| .loading-spinner { |
| width: 50px; |
| height: 50px; |
| border: 4px solid rgba(139, 92, 246, 0.2); |
| border-top-color: #8b5cf6; |
| border-radius: 50%; |
| animation: spin 1s linear infinite; |
| margin-bottom: var(--space-4); |
| } |
|
|
| @keyframes spin { |
| to { transform: rotate(360deg); } |
| } |
|
|
| .loading-text { |
| color: var(--text-muted); |
| font-size: var(--font-size-base); |
| } |
|
|
| .empty-state { |
| grid-column: 1 / -1; |
| text-align: center; |
| padding: var(--space-16); |
| color: var(--text-muted); |
| } |
|
|
| .empty-icon { |
| font-size: 64px; |
| margin-bottom: var(--space-4); |
| opacity: 0.3; |
| } |
|
|
| |
| |
| |
|
|
| @media (max-width: 1200px) { |
| .stats-grid { |
| grid-template-columns: repeat(2, 1fr); |
| } |
| } |
|
|
| @media (max-width: 768px) { |
| .page-header.glass-panel { |
| flex-direction: column; |
| text-align: center; |
| gap: var(--space-4); |
| } |
| |
| .page-title { |
| flex-direction: column; |
| } |
| |
| .stats-grid { |
| grid-template-columns: 1fr; |
| } |
| |
| .tabs { |
| flex-wrap: wrap; |
| } |
| |
| .tab-btn { |
| flex: 1; |
| justify-content: center; |
| min-width: 120px; |
| } |
| |
| .models-grid, |
| .health-grid, |
| .catalog-grid { |
| grid-template-columns: 1fr; |
| } |
| |
| .section-header { |
| flex-direction: column; |
| gap: var(--space-3); |
| } |
| |
| .filter-controls { |
| width: 100%; |
| } |
| |
| .filter-controls select { |
| flex: 1; |
| } |
| } |
|
|