body{font-family:var(--font-sans);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}.app-container{display:flex;min-height:100vh}.sidebar{width:200px;background:var(--bg-secondary);border-right:1px solid var(--border-primary);display:flex;flex-direction:column;position:fixed;height:100vh;left:0;top:0;overflow-y:auto;z-index:100}.logo{padding:16px;border-bottom:1px solid var(--border-primary);display:flex;align-items:center;gap:10px}.logo-icon{width:28px;height:28px;color:var(--color-primary)}.logo-icon svg{width:100%;height:100%}.logo-text{display:flex;align-items:center;gap:6px}.logo-title{font-size:15px;font-weight:700;color:var(--text-primary);letter-spacing:1px}.logo-badge{font-size:9px;font-weight:700;background:var(--color-primary);color:var(--bg-primary);padding:2px 5px;border-radius:2px;letter-spacing:.5px}.social-links{display:flex;align-items:center;gap:12px;padding:10px 16px;border-bottom:1px solid var(--border-primary)}.social-link{display:flex;align-items:center;justify-content:center;width:28px;height:28px;color:var(--text-tertiary);border-radius:6px;transition:all .2s ease}.social-link:hover{color:var(--color-primary);background:var(--bg-tertiary)}.social-link svg{width:18px;height:18px}.nav-menu{flex:1;padding:8px 0;overflow-y:auto}.nav-menu::-webkit-scrollbar{width:4px}.nav-menu::-webkit-scrollbar-track{background:transparent}.nav-menu::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:2px}.nav-section{margin-bottom:4px}.nav-section-title{padding:12px 16px 6px;font-size:12px;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.nav-item{display:flex;align-items:center;gap:10px;padding:9px 16px;color:var(--text-secondary);text-decoration:none;transition:all .15s ease;position:relative;font-size:14px;border-left:2px solid transparent}.nav-item:hover{background:var(--bg-tertiary);color:var(--text-primary)}.nav-item.router-link-active{background:#f0b90b14;color:var(--color-primary);border-left-color:var(--color-primary)}.nav-item.router-link-active .nav-icon{color:var(--color-primary)}.nav-icon{width:18px;height:18px;color:var(--text-tertiary);flex-shrink:0;transition:color .15s ease}.nav-icon svg{width:100%;height:100%}.nav-text{flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.exchange-logo{width:18px;height:18px;border-radius:4px;object-fit:cover;flex-shrink:0}.chain-tag{font-size:10px;background:var(--bg-tertiary);padding:2px 5px;border-radius:2px;color:var(--text-secondary);font-weight:500}.status-indicator{width:6px;height:6px;border-radius:50%;flex-shrink:0;margin-left:auto}.status-indicator.large{width:8px;height:8px}.status-indicator.online{background:var(--color-up);box-shadow:0 0 8px var(--color-up);animation:breathing 2s ease-in-out infinite}.status-indicator.offline{background:var(--text-muted)}.sidebar-footer{padding:12px 16px;border-top:1px solid var(--border-primary);background:var(--bg-tertiary)}.connection-row{display:flex;align-items:center;gap:8px;margin-bottom:8px}.conn-text{font-size:12px;color:var(--text-secondary)}.stats-row{margin-bottom:6px}.stat-item{font-size:12px;display:flex;align-items:center;gap:2px}.stat-value{color:var(--color-primary);font-weight:600;font-family:var(--font-mono)}.stat-sep{color:var(--text-muted)}.stat-total{color:var(--text-secondary);font-family:var(--font-mono)}.stat-label{color:var(--text-tertiary);margin-left:4px}.time-row{font-size:11px;color:var(--text-tertiary);font-family:var(--font-mono)}.pro-badge{font-size:9px;font-weight:700;background:var(--color-primary);color:var(--bg-primary);padding:2px 5px;border-radius:2px;margin-left:auto}.user-section{padding:12px 16px;border-top:1px solid var(--border-primary)}.user-info{display:flex;align-items:center;gap:10px;margin-bottom:10px}.user-avatar{width:32px;height:32px;background:var(--color-primary);color:var(--bg-primary);border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700}.user-details{display:flex;flex-direction:column;gap:2px;overflow:hidden}.user-email{font-size:12px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.user-status{font-size:10px;color:var(--text-tertiary)}.user-status.is-premium{color:var(--color-primary);font-weight:600}.user-actions{display:flex;gap:8px}.upgrade-btn{flex:1;padding:6px 10px;background:var(--color-primary);color:var(--bg-primary);font-size:11px;font-weight:600;text-align:center;text-decoration:none;border-radius:4px}.logout-btn{padding:6px 10px;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-secondary);font-size:11px;cursor:pointer;border-radius:4px}.logout-btn:hover{background:var(--border-primary);color:var(--text-primary)}.auth-buttons{display:flex;gap:8px}.login-btn,.register-btn{flex:1;padding:8px 12px;font-size:12px;font-weight:500;text-align:center;text-decoration:none;border-radius:4px}.login-btn{background:transparent;border:1px solid var(--border-primary);color:var(--text-secondary)}.login-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.register-btn{background:var(--color-primary);color:var(--bg-primary);border:none}.main-content{flex:1;margin-left:200px;padding:16px;min-height:100vh;background:var(--bg-primary)}.crown-icon{font-size:12px;margin-left:auto;filter:drop-shadow(0 0 2px rgba(255,215,0,.5));animation:crown-glow 2s ease-in-out infinite}@keyframes crown-glow{0%,to{filter:drop-shadow(0 0 2px rgba(255,215,0,.5))}50%{filter:drop-shadow(0 0 6px rgba(255,215,0,.8))}}.mobile-header{display:none;position:fixed;top:0;left:0;right:0;height:56px;background:var(--bg-secondary);border-bottom:1px solid var(--border-primary);z-index:200;align-items:center;padding:0 16px;gap:12px}.menu-toggle{width:40px;height:40px;border:none;background:transparent;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;justify-content:center;border-radius:8px}.menu-toggle:hover{background:var(--bg-tertiary)}.menu-toggle svg{width:24px;height:24px}.mobile-logo{display:flex;align-items:center;gap:6px}.sidebar-overlay{display:none;position:fixed;top:0;right:0;bottom:0;left:0;background:#0009;z-index:150;opacity:0;transition:opacity .3s;pointer-events:none}.sidebar-overlay.visible{opacity:1;pointer-events:auto}@media (max-width: 1024px){.main-content{padding:12px}}@media (max-width: 768px){.mobile-header{display:flex}.sidebar-overlay{display:block}.sidebar{transform:translate(-100%);transition:transform .3s ease;z-index:160}.sidebar.open{transform:translate(0)}.main-content{margin-left:0;padding:68px 12px 12px}.crown-icon{font-size:10px}}@media (max-width: 480px){.main-content{padding:64px 8px 8px}.sidebar{width:260px}.user-section{padding:10px 12px}.user-avatar{width:28px;height:28px;font-size:12px}.user-email{font-size:11px}.nav-item{padding:8px 14px;font-size:13px}.nav-icon{width:16px;height:16px}}:root{--bg-primary: #0b0e11;--bg-secondary: #12161c;--bg-tertiary: #181c23;--bg-elevated: #1e2329;--bg-hover: rgba(255, 255, 255, .04);--bg-active: rgba(255, 255, 255, .08);--border-primary: #2b3139;--border-secondary: #363c45;--border-subtle: rgba(255, 255, 255, .06);--text-primary: #eaecef;--text-secondary: #c9cdd4;--text-tertiary: #a0a7b3;--text-muted: #848e9c;--color-up: #0ecb81;--color-up-bg: rgba(14, 203, 129, .12);--color-up-border: rgba(14, 203, 129, .25);--color-down: #f6465d;--color-down-bg: rgba(246, 70, 93, .12);--color-down-border: rgba(246, 70, 93, .25);--color-primary: #f0b90b;--color-primary-hover: #ffcd39;--color-primary-bg: rgba(240, 185, 11, .12);--color-accent: #1e90ff;--color-accent-bg: rgba(30, 144, 255, .12);--color-warning: #f7931a;--color-warning-bg: rgba(247, 147, 26, .12);--color-danger: #f6465d;--color-danger-bg: rgba(246, 70, 93, .12);--color-info: #71a1ff;--color-info-bg: rgba(113, 161, 255, .12);--level-1: #848e9c;--level-2: #f7931a;--level-3: #0ecb81;--level-critical: #f6465d;--sidebar-width: 200px;--header-height: 48px;--border-radius-sm: 2px;--border-radius-md: 4px;--border-radius-lg: 6px;--font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, "Helvetica Neue", Arial, sans-serif;--font-mono: "SF Mono", "Roboto Mono", "Fira Code", Consolas, monospace;--font-size-xs: 12px;--font-size-sm: 13px;--font-size-md: 14px;--font-size-lg: 15px;--font-size-xl: 17px;--font-size-2xl: 22px;--font-size-3xl: 26px;--spacing-xs: 4px;--spacing-sm: 8px;--spacing-md: 12px;--spacing-lg: 16px;--spacing-xl: 20px;--spacing-2xl: 24px;--transition-fast: .1s ease;--transition-normal: .2s ease;--transition-slow: .3s ease}*{margin:0;padding:0;box-sizing:border-box}html{touch-action:manipulation;-webkit-tap-highlight-color:transparent}body{font-family:var(--font-family);font-size:var(--font-size-md);color:var(--text-primary);background:var(--bg-primary);line-height:1.5;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;-webkit-text-size-adjust:100%;text-size-adjust:100%}button,input,select,textarea,a,[role=button],.clickable{touch-action:manipulation;-webkit-tap-highlight-color:transparent}button,[role=button]{cursor:pointer;min-height:44px}@media (max-width: 768px){input,select,textarea{font-size:16px!important}}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:transparent}::-webkit-scrollbar-thumb{background:var(--border-secondary);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary)}.pro-table{width:100%;border-collapse:collapse;font-size:var(--font-size-sm)}.pro-table th,.pro-table td{padding:var(--spacing-sm) var(--spacing-md);text-align:right;border-bottom:1px solid var(--border-subtle);white-space:nowrap}.pro-table th{background:var(--bg-tertiary);font-weight:500;color:var(--text-tertiary);font-size:var(--font-size-xs);text-transform:uppercase;letter-spacing:.3px;position:sticky;top:0;z-index:10}.pro-table th:first-child,.pro-table td:first-child{text-align:left;padding-left:var(--spacing-lg)}.pro-table th:last-child,.pro-table td:last-child{padding-right:var(--spacing-lg)}.pro-table tbody tr{transition:background var(--transition-fast)}.pro-table tbody tr:hover{background:var(--bg-hover)}.pro-table.compact th,.pro-table.compact td{padding:var(--spacing-xs) var(--spacing-sm)}.cell-symbol{font-weight:600;color:var(--text-primary)}.cell-price{font-family:var(--font-mono);color:var(--text-secondary)}.cell-change{font-family:var(--font-mono);font-weight:500}.cell-change.up,.text-up{color:var(--color-up)}.cell-change.down,.text-down{color:var(--color-down)}.cell-change.neutral{color:var(--text-tertiary)}.pro-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--border-radius-md);padding:var(--spacing-lg)}.pro-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--spacing-md);padding-bottom:var(--spacing-sm);border-bottom:1px solid var(--border-subtle)}.pro-card-title{font-size:var(--font-size-md);font-weight:600;color:var(--text-primary)}.stat-card{background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--border-radius-md);padding:var(--spacing-md) var(--spacing-lg);border-left:3px solid var(--border-primary)}.stat-card .label{font-size:var(--font-size-xs);color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px;margin-bottom:var(--spacing-xs)}.stat-card .value{font-size:var(--font-size-2xl);font-weight:600;font-family:var(--font-mono);color:var(--text-primary)}.stat-card .detail{font-size:var(--font-size-xs);color:var(--text-secondary);margin-top:var(--spacing-xs)}.stat-card.level-3{border-left-color:var(--color-up)}.stat-card.level-2{border-left-color:var(--color-warning)}.stat-card.level-1{border-left-color:var(--text-tertiary)}.stat-card.up{border-left-color:var(--color-up)}.stat-card.up .value{color:var(--color-up)}.stat-card.down{border-left-color:var(--color-down)}.stat-card.down .value{color:var(--color-down)}.stat-card.highlight{border-left-color:var(--color-primary);background:linear-gradient(90deg,var(--color-primary-bg),transparent)}.pro-btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--spacing-xs);padding:var(--spacing-sm) var(--spacing-lg);border-radius:var(--border-radius-md);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;transition:var(--transition-fast);border:none;outline:none;font-family:inherit}.pro-btn-primary{background:var(--color-primary);color:var(--bg-primary)}.pro-btn-primary:hover{background:var(--color-primary-hover)}.pro-btn-secondary{background:var(--bg-elevated);color:var(--text-secondary);border:1px solid var(--border-secondary)}.pro-btn-secondary:hover{background:var(--bg-hover);color:var(--text-primary);border-color:var(--text-tertiary)}.pro-btn-ghost{background:transparent;color:var(--text-secondary)}.pro-btn-ghost:hover{background:var(--bg-hover);color:var(--text-primary)}.pro-btn-ghost.active{background:var(--color-primary-bg);color:var(--color-primary)}.pro-btn-sm{padding:var(--spacing-xs) var(--spacing-sm);font-size:var(--font-size-xs)}.pro-tag{display:inline-flex;align-items:center;padding:2px var(--spacing-sm);border-radius:var(--border-radius-sm);font-size:var(--font-size-xs);font-weight:500}.pro-tag-default{background:var(--bg-elevated);color:var(--text-secondary)}.pro-tag-up{background:var(--color-up-bg);color:var(--color-up)}.pro-tag-down{background:var(--color-down-bg);color:var(--color-down)}.pro-tag-warning{background:var(--color-warning-bg);color:var(--color-warning)}.pro-tag-danger{background:var(--color-danger-bg);color:var(--color-danger)}.pro-tag-info{background:var(--color-info-bg);color:var(--color-info)}.pro-tag-level-1{background:#848e9c26;color:var(--level-1)}.pro-tag-level-2{background:#f7931a26;color:var(--level-2)}.pro-tag-level-3{background:#0ecb8126;color:var(--level-3)}.pro-input{padding:var(--spacing-sm) var(--spacing-md);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:var(--font-size-sm);transition:var(--transition-fast);outline:none;font-family:inherit}.pro-input:focus{border-color:var(--color-primary);box-shadow:0 0 0 2px var(--color-primary-bg)}.pro-input::placeholder{color:var(--text-tertiary)}.pro-select{padding:var(--spacing-sm) var(--spacing-md);padding-right:var(--spacing-2xl);background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--border-radius-md);color:var(--text-primary);font-size:var(--font-size-sm);cursor:pointer;-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' viewBox='0 0 24 24' fill='none' stroke='%23848e9c' stroke-width='2'%3E%3Cpath d='M6 9l6 6 6-6'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 8px center;font-family:inherit}.pro-select:focus{border-color:var(--color-primary);outline:none}.pro-tabs{display:flex;gap:var(--spacing-xs);border-bottom:1px solid var(--border-primary)}.pro-tab{padding:var(--spacing-sm) var(--spacing-lg);color:var(--text-secondary);font-size:var(--font-size-sm);font-weight:500;cursor:pointer;border:none;background:transparent;position:relative;transition:var(--transition-fast);font-family:inherit}.pro-tab:hover{color:var(--text-primary)}.pro-tab.active{color:var(--color-primary)}.pro-tab.active:after{content:"";position:absolute;bottom:-1px;left:0;right:0;height:2px;background:var(--color-primary)}.filter-group{display:flex;gap:var(--spacing-xs)}.filter-btn{padding:var(--spacing-xs) var(--spacing-md);background:transparent;border:1px solid var(--border-primary);border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-xs);cursor:pointer;transition:var(--transition-fast);font-family:inherit}.filter-btn:hover{border-color:var(--text-tertiary);color:var(--text-primary)}.filter-btn.active{background:var(--color-primary-bg);border-color:var(--color-primary);color:var(--color-primary)}.status-dot{width:6px;height:6px;border-radius:50%;flex-shrink:0}.status-dot.connected{background:var(--color-up);box-shadow:0 0 6px var(--color-up);animation:breathing 2s ease-in-out infinite}.status-dot.disconnected{background:var(--text-tertiary)}@keyframes breathing{0%,to{opacity:1;box-shadow:0 0 4px var(--color-up)}50%{opacity:.7;box-shadow:0 0 8px var(--color-up)}}@keyframes flash-up{0%{background:var(--color-up-bg)}to{background:transparent}}@keyframes flash-down{0%{background:var(--color-down-bg)}to{background:transparent}}.flash-up{animation:flash-up .4s ease-out}.flash-down{animation:flash-down .4s ease-out}@keyframes slide-in{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.slide-in{animation:slide-in .25s ease-out}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}.alert-normal{color:var(--color-up)}.alert-warning{color:var(--color-warning)}.alert-danger{color:#ff9800}.alert-critical{color:var(--color-danger)}.empty-state{text-align:center;padding:var(--spacing-2xl);color:var(--text-tertiary)}.empty-state .icon{font-size:32px;margin-bottom:var(--spacing-md);opacity:.5}.pro-pagination{display:flex;justify-content:center;align-items:center;gap:var(--spacing-md);margin-top:var(--spacing-lg)}.pro-pagination button{padding:var(--spacing-xs) var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--border-radius-md);color:var(--text-secondary);font-size:var(--font-size-sm);cursor:pointer;transition:var(--transition-fast);font-family:inherit}.pro-pagination button:hover:not(:disabled){border-color:var(--text-tertiary);color:var(--text-primary)}.pro-pagination button:disabled{opacity:.4;cursor:not-allowed}.pro-pagination span{font-size:var(--font-size-sm);color:var(--text-tertiary);font-family:var(--font-mono)}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:var(--spacing-md)}.stats-grid-4{grid-template-columns:repeat(4,1fr)}.stats-grid-3{grid-template-columns:repeat(3,1fr)}@media (max-width: 1200px){.stats-grid-4{grid-template-columns:repeat(2,1fr)}}@media (max-width: 768px){.stats-grid-4,.stats-grid-3{grid-template-columns:1fr}}.exchange-logo{width:20px;height:20px;border-radius:var(--border-radius-sm);object-fit:cover;flex-shrink:0}.exchange-logo-sm{width:16px;height:16px}.chain-badge{font-size:var(--font-size-xs);background:var(--bg-elevated);padding:1px 4px;border-radius:var(--border-radius-sm);color:var(--text-tertiary)}.pro-toolbar{display:flex;align-items:center;gap:var(--spacing-md);padding:var(--spacing-md) 0;flex-wrap:wrap}.pro-toolbar-left{display:flex;align-items:center;gap:var(--spacing-md)}.pro-toolbar-right{display:flex;align-items:center;gap:var(--spacing-sm);margin-left:auto}.page-header{margin-bottom:var(--spacing-lg)}.page-title{font-size:var(--font-size-xl);font-weight:600;color:var(--text-primary);margin-bottom:var(--spacing-xs)}.page-subtitle{font-size:var(--font-size-sm);color:var(--text-secondary)}.signal-item{display:flex;align-items:flex-start;gap:var(--spacing-md);padding:var(--spacing-md);background:var(--bg-secondary);border:1px solid var(--border-primary);border-left:3px solid var(--border-primary);border-radius:var(--border-radius-md);margin-bottom:var(--spacing-sm);transition:var(--transition-fast)}.signal-item:hover{background:var(--bg-hover)}.signal-item.level-3{border-left-color:var(--color-up)}.signal-item.level-2{border-left-color:var(--color-warning)}.signal-item.level-1{border-left-color:var(--text-tertiary)}.signal-symbol{font-weight:600;font-size:var(--font-size-lg);color:var(--text-primary)}.signal-rule{font-size:var(--font-size-xs);color:var(--text-tertiary)}.signal-message{font-size:var(--font-size-sm);color:var(--text-secondary)}.signal-time{font-size:var(--font-size-xs);color:var(--text-muted);font-family:var(--font-mono)}.oi-bar{display:flex;height:6px;border-radius:3px;overflow:hidden;background:var(--bg-elevated)}.oi-segment{transition:width var(--transition-normal)}.oi-segment.binance{background:#f0b90b}.oi-segment.bybit{background:#f7931a}.oi-segment.okx{background:#888}.oi-segment.bitget{background:#00b897}.price-with-platform{display:flex;align-items:center;gap:var(--spacing-xs)}.platform-badge{font-size:var(--font-size-xs);padding:1px 4px;border-radius:var(--border-radius-sm);background:var(--color-primary-bg);color:var(--color-primary)}.mono{font-family:var(--font-mono)}
