Your Name
feat: UI improvements and error suppression - Enhanced dashboard and market pages with improved header buttons, logo, and currency symbol display - Stopped animated ticker - Removed pie chart legends - Added error suppressor for external service errors (SSE, Permissions-Policy warnings) - Improved header button prominence and icon appearance - Enhanced logo with glow effects and better design - Fixed currency symbol visibility in market tables
8b7b267
| /** | |
| * UI Enhancements - Professional Grade | |
| * Complete styling for all components | |
| */ | |
| :root { | |
| /* Enhanced Color Palette */ | |
| --primary: #2dd4bf; | |
| --primary-dark: #14b8a6; | |
| --primary-light: #5eead4; | |
| --secondary: #3b82f6; | |
| --success: #10b981; | |
| --warning: #f59e0b; | |
| --danger: #ef4444; | |
| --info: #06b6d4; | |
| /* Background Colors */ | |
| --bg-primary: #0a0e27; | |
| --bg-secondary: #0f1419; | |
| --bg-card: rgba(15, 20, 25, 0.9); | |
| --bg-hover: rgba(255, 255, 255, 0.05); | |
| /* Text Colors */ | |
| --text-primary: #ffffff; | |
| --text-secondary: #94a3b8; | |
| --text-muted: #64748b; | |
| /* Shadows */ | |
| --shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, 0.05); | |
| --shadow: 0 4px 6px -1px rgba(0, 0, 0, 0.1); | |
| --shadow-md: 0 8px 16px -2px rgba(0, 0, 0, 0.2); | |
| --shadow-lg: 0 20px 25px -5px rgba(0, 0, 0, 0.3); | |
| --shadow-xl: 0 25px 50px -12px rgba(0, 0, 0, 0.5); | |
| /* Border Radius */ | |
| --radius-sm: 0.375rem; | |
| --radius: 0.5rem; | |
| --radius-md: 0.75rem; | |
| --radius-lg: 1rem; | |
| --radius-xl: 1.5rem; | |
| /* Transitions */ | |
| --transition: all 0.3s cubic-bezier(0.4, 0, 0.2, 1); | |
| --transition-fast: all 0.15s cubic-bezier(0.4, 0, 0.2, 1); | |
| } | |
| /* Global Enhancements */ | |
| * { | |
| outline-color: var(--primary); | |
| } | |
| body { | |
| font-family: 'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', system-ui, sans-serif; | |
| -webkit-font-smoothing: antialiased; | |
| -moz-osx-font-smoothing: grayscale; | |
| text-rendering: optimizeLegibility; | |
| } | |
| /* Enhanced Buttons */ | |
| .btn, | |
| button:not(.unstyled) { | |
| position: relative; | |
| display: inline-flex; | |
| align-items: center; | |
| justify-content: center; | |
| gap: 0.5rem; | |
| padding: 0.625rem 1.25rem; | |
| font-size: 0.875rem; | |
| font-weight: 600; | |
| line-height: 1.5; | |
| text-align: center; | |
| white-space: nowrap; | |
| border: 1px solid transparent; | |
| border-radius: var(--radius-md); | |
| cursor: pointer; | |
| user-select: none; | |
| transition: var(--transition); | |
| overflow: hidden; | |
| } | |
| .btn::before { | |
| content: ''; | |
| position: absolute; | |
| inset: 0; | |
| background: radial-gradient(circle at center, rgba(255,255,255,0.15) 0%, transparent 70%); | |
| opacity: 0; | |
| transition: opacity 0.3s; | |
| } | |
| .btn:hover::before { | |
| opacity: 1; | |
| } | |
| .btn:active { | |
| transform: scale(0.98); | |
| } | |
| .btn:disabled { | |
| opacity: 0.5; | |
| cursor: not-allowed; | |
| pointer-events: none; | |
| } | |
| /* Button Variants */ | |
| .btn-primary, | |
| .btn-gradient { | |
| background: linear-gradient(135deg, var(--primary) 0%, var(--secondary) 100%); | |
| color: white; | |
| box-shadow: 0 4px 12px rgba(45, 212, 191, 0.3); | |
| } | |
| .btn-primary:hover, | |
| .btn-gradient:hover { | |
| box-shadow: 0 6px 16px rgba(45, 212, 191, 0.4); | |
| transform: translateY(-2px); | |
| } | |
| .btn-secondary { | |
| background: var(--bg-card); | |
| color: var(--text-primary); | |
| border-color: rgba(255, 255, 255, 0.1); | |
| } | |
| .btn-secondary:hover { | |
| background: var(--bg-hover); | |
| border-color: rgba(255, 255, 255, 0.2); | |
| } | |
| .btn-success { | |
| background: var(--success); | |
| color: white; | |
| } | |
| .btn-success:hover { | |
| background: #059669; | |
| } | |
| .btn-danger { | |
| background: var(--danger); | |
| color: white; | |
| } | |
| .btn-danger:hover { | |
| background: #dc2626; | |
| } | |
| .btn-warning { | |
| background: var(--warning); | |
| color: white; | |
| } | |
| .btn-warning:hover { | |
| background: #d97706; | |
| } | |
| /* Button Sizes */ | |
| .btn-sm { | |
| padding: 0.375rem 0.75rem; | |
| font-size: 0.8125rem; | |
| } | |
| .btn-lg { | |
| padding: 0.875rem 1.75rem; | |
| font-size: 1rem; | |
| } | |
| .btn-block { | |
| width: 100%; | |
| } | |
| /* Icon Buttons */ | |
| .btn-icon { | |
| padding: 0.5rem; | |
| width: 2.5rem; | |
| height: 2.5rem; | |
| background: var(--bg-card); | |
| border: 1px solid rgba(255, 255, 255, 0.1); | |
| border-radius: var(--radius-md); | |
| color: var(--text-primary); | |
| transition: var(--transition); | |
| } | |
| .btn-icon:hover { | |
| background: var(--bg-hover); | |
| border-color: var(--primary); | |
| color: var(--primary); | |
| transform: translateY(-2px); | |
| } | |
| .btn-icon svg { | |
| width: 1.25rem; | |
| height: 1.25rem; | |
| } | |
| /* Enhanced Cards */ | |
| .card, | |
| .panel-card, | |
| .stat-card { | |
| background: var(--bg-card); | |
| border: 1px solid rgba(255, 255, 255, 0.08); | |
| border-radius: var(--radius-lg); | |
| padding: 1.5rem; | |
| transition: var(--transition); | |
| backdrop-filter: blur(20px); | |
| } | |
| .card:hover, | |
| .panel-card:hover { | |
| border-color: rgba(255, 255, 255, 0.15); | |
| box-shadow: var(--shadow-lg); | |
| transform: translateY(-2px); | |
| } | |
| /* Enhanced Forms */ | |
| .form-input, | |
| .form-select, | |
| .form-textarea, | |
| select, | |
| input[type="text"], | |
| input[type="email"], | |
| input[type="password"], | |
| input[type="number"], | |
| textarea { | |
| width: 100%; | |
| padding: 0.625rem 1rem; | |
| font-size: 0.875rem; | |
| line-height: 1.5; | |
| color: var(--text-primary); | |
| background: rgba(255, 255, 255, 0.05); | |
| border: 1px solid rgba(255, 255, 255, 0.1); | |
| border-radius: var(--radius-md); | |
| transition: var(--transition); | |
| } | |
| .form-input:focus, | |
| .form-select:focus, | |
| .form-textarea:focus, | |
| select:focus, | |
| input:focus, | |
| textarea:focus { | |
| outline: none; | |
| border-color: var(--primary); | |
| box-shadow: 0 0 0 3px rgba(45, 212, 191, 0.1); | |
| background: rgba(255, 255, 255, 0.08); | |
| } | |
| .form-input:disabled, | |
| .form-select:disabled, | |
| select:disabled, | |
| input:disabled { | |
| opacity: 0.5; | |
| cursor: not-allowed; | |
| } | |
| /* Enhanced Select with Icon */ | |
| .form-select, | |
| select { | |
| appearance: none; | |
| background-image: url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='20' height='20' viewBox='0 0 24 24' fill='none' stroke='%2394a3b8' 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 0.75rem center; | |
| background-size: 1.25rem; | |
| padding-right: 2.5rem; | |
| } | |
| /* Loading States */ | |
| .spinner, | |
| .loading-spinner { | |
| display: inline-block; | |
| width: 2rem; | |
| height: 2rem; | |
| border: 3px solid rgba(255, 255, 255, 0.1); | |
| border-top-color: var(--primary); | |
| border-radius: 50%; | |
| animation: spin 0.8s linear infinite; | |
| } | |
| @keyframes spin { | |
| to { | |
| transform: rotate(360deg); | |
| } | |
| } | |
| .loading-container { | |
| display: flex; | |
| flex-direction: column; | |
| align-items: center; | |
| justify-content: center; | |
| gap: 1rem; | |
| padding: 3rem; | |
| text-align: center; | |
| } | |
| /* Enhanced Toast/Notifications */ | |
| .toast, | |
| #toast-container > div { | |
| position: fixed; | |
| top: 1rem; | |
| right: 1rem; | |
| min-width: 300px; | |
| max-width: 500px; | |
| padding: 1rem 1.25rem; | |
| background: var(--bg-card); | |
| border: 1px solid rgba(255, 255, 255, 0.1); | |
| border-radius: var(--radius-lg); | |
| box-shadow: var(--shadow-xl); | |
| backdrop-filter: blur(20px); | |
| animation: slideInRight 0.3s ease-out; | |
| z-index: 9999; | |
| } | |
| @keyframes slideInRight { | |
| from { | |
| transform: translateX(100%); | |
| opacity: 0; | |
| } | |
| to { | |
| transform: translateX(0); | |
| opacity: 1; | |
| } | |
| } | |
| .toast.success { | |
| border-left: 4px solid var(--success); | |
| } | |
| .toast.error { | |
| border-left: 4px solid var(--danger); | |
| } | |
| .toast.warning { | |
| border-left: 4px solid var(--warning); | |
| } | |
| .toast.info { | |
| border-left: 4px solid var(--info); | |
| } | |
| /* Enhanced Modal */ | |
| .modal { | |
| position: fixed; | |
| inset: 0; | |
| z-index: 9998; | |
| display: none; | |
| align-items: center; | |
| justify-content: center; | |
| padding: 1rem; | |
| } | |
| .modal.active { | |
| display: flex; | |
| } | |
| .modal-backdrop { | |
| position: absolute; | |
| inset: 0; | |
| background: rgba(0, 0, 0, 0.75); | |
| backdrop-filter: blur(4px); | |
| animation: fadeIn 0.2s ease-out; | |
| } | |
| @keyframes fadeIn { | |
| from { opacity: 0; } | |
| to { opacity: 1; } | |
| } | |
| .modal-content { | |
| position: relative; | |
| max-width: 600px; | |
| width: 100%; | |
| max-height: 90vh; | |
| background: var(--bg-card); | |
| border: 1px solid rgba(255, 255, 255, 0.1); | |
| border-radius: var(--radius-xl); | |
| box-shadow: var(--shadow-xl); | |
| overflow: hidden; | |
| animation: slideUp 0.3s ease-out; | |
| } | |
| @keyframes slideUp { | |
| from { | |
| transform: translateY(2rem); | |
| opacity: 0; | |
| } | |
| to { | |
| transform: translateY(0); | |
| opacity: 1; | |
| } | |
| } | |
| /* Enhanced Icons */ | |
| svg:not(.unstyled) { | |
| flex-shrink: 0; | |
| } | |
| .icon { | |
| display: inline-flex; | |
| align-items: center; | |
| justify-content: center; | |
| width: 1.5rem; | |
| height: 1.5rem; | |
| } | |
| .icon-sm { | |
| width: 1rem; | |
| height: 1rem; | |
| } | |
| .icon-lg { | |
| width: 2rem; | |
| height: 2rem; | |
| } | |
| .icon-xl { | |
| width: 3rem; | |
| height: 3rem; | |
| } | |
| /* Enhanced Badges */ | |
| .badge { | |
| display: inline-flex; | |
| align-items: center; | |
| gap: 0.25rem; | |
| padding: 0.25rem 0.75rem; | |
| font-size: 0.75rem; | |
| font-weight: 600; | |
| line-height: 1; | |
| border-radius: 9999px; | |
| white-space: nowrap; | |
| } | |
| .badge-primary { | |
| background: rgba(45, 212, 191, 0.2); | |
| color: var(--primary); | |
| } | |
| .badge-success { | |
| background: rgba(16, 185, 129, 0.2); | |
| color: var(--success); | |
| } | |
| .badge-warning { | |
| background: rgba(245, 158, 11, 0.2); | |
| color: var(--warning); | |
| } | |
| .badge-danger { | |
| background: rgba(239, 68, 68, 0.2); | |
| color: var(--danger); | |
| } | |
| /* Enhanced Tooltips */ | |
| [data-tooltip] { | |
| position: relative; | |
| } | |
| [data-tooltip]::after { | |
| content: attr(data-tooltip); | |
| position: absolute; | |
| bottom: calc(100% + 0.5rem); | |
| left: 50%; | |
| transform: translateX(-50%) translateY(-0.25rem); | |
| padding: 0.5rem 0.75rem; | |
| font-size: 0.75rem; | |
| line-height: 1.2; | |
| white-space: nowrap; | |
| background: var(--bg-secondary); | |
| border: 1px solid rgba(255, 255, 255, 0.1); | |
| border-radius: var(--radius); | |
| opacity: 0; | |
| pointer-events: none; | |
| transition: opacity 0.2s, transform 0.2s; | |
| z-index: 9999; | |
| } | |
| [data-tooltip]:hover::after { | |
| opacity: 1; | |
| transform: translateX(-50%) translateY(0); | |
| } | |
| /* Responsive Utilities */ | |
| @media (max-width: 768px) { | |
| .btn { | |
| font-size: 0.8125rem; | |
| padding: 0.5rem 1rem; | |
| } | |
| .card { | |
| padding: 1rem; | |
| } | |
| .modal-content { | |
| margin: 1rem; | |
| } | |
| } | |
| /* Enhanced Scrollbar */ | |
| ::-webkit-scrollbar { | |
| width: 0.5rem; | |
| height: 0.5rem; | |
| } | |
| ::-webkit-scrollbar-track { | |
| background: rgba(255, 255, 255, 0.05); | |
| } | |
| ::-webkit-scrollbar-thumb { | |
| background: rgba(255, 255, 255, 0.2); | |
| border-radius: 0.25rem; | |
| } | |
| ::-webkit-scrollbar-thumb:hover { | |
| background: rgba(255, 255, 255, 0.3); | |
| } | |
| /* Enhanced Focus States */ | |
| *:focus-visible { | |
| outline: 2px solid var(--primary); | |
| outline-offset: 2px; | |
| } | |
| /* Enhanced Selection */ | |
| ::selection { | |
| background: rgba(45, 212, 191, 0.3); | |
| color: var(--text-primary); | |
| } | |
| /* Accessibility Enhancements */ | |
| .sr-only { | |
| position: absolute; | |
| width: 1px; | |
| height: 1px; | |
| padding: 0; | |
| margin: -1px; | |
| overflow: hidden; | |
| clip: rect(0, 0, 0, 0); | |
| white-space: nowrap; | |
| border-width: 0; | |
| } | |
| /* Enhanced Animations */ | |
| @keyframes pulse { | |
| 0%, 100% { | |
| opacity: 1; | |
| } | |
| 50% { | |
| opacity: 0.5; | |
| } | |
| } | |
| .pulse { | |
| animation: pulse 2s cubic-bezier(0.4, 0, 0.6, 1) infinite; | |
| } | |
| @keyframes bounce { | |
| 0%, 100% { | |
| transform: translateY(-25%); | |
| animation-timing-function: cubic-bezier(0.8, 0, 1, 1); | |
| } | |
| 50% { | |
| transform: translateY(0); | |
| animation-timing-function: cubic-bezier(0, 0, 0.2, 1); | |
| } | |
| } | |
| .bounce { | |
| animation: bounce 1s infinite; | |
| } | |
| /* Print Styles */ | |
| @media print { | |
| .btn, | |
| .modal, | |
| .toast, | |
| .sidebar { | |
| display: none ; | |
| } | |
| } | |