.react-flow{direction:ltr}.react-flow__container{position:absolute;width:100%;height:100%;top:0;left:0}.react-flow__pane{z-index:1;cursor:-webkit-grab;cursor:grab}.react-flow__pane.selection{cursor:pointer}.react-flow__pane.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__viewport{transform-origin:0 0;z-index:2;pointer-events:none}.react-flow__renderer{z-index:4}.react-flow__selection{z-index:6}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible{outline:none}.react-flow .react-flow__edges{pointer-events:none;overflow:visible}.react-flow__edge-path,.react-flow__connection-path{stroke:#b1b1b7;stroke-width:1;fill:none}.react-flow__edge{pointer-events:visibleStroke;cursor:pointer}.react-flow__edge.animated path{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__edge.animated path.react-flow__edge-interaction{stroke-dasharray:none;-webkit-animation:none;animation:none}.react-flow__edge.inactive{pointer-events:none}.react-flow__edge.selected,.react-flow__edge:focus,.react-flow__edge:focus-visible{outline:none}.react-flow__edge.selected .react-flow__edge-path,.react-flow__edge:focus .react-flow__edge-path,.react-flow__edge:focus-visible .react-flow__edge-path{stroke:#555}.react-flow__edge-textwrapper{pointer-events:all}.react-flow__edge-textbg{fill:#fff}.react-flow__edge .react-flow__edge-text{pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__connection{pointer-events:none}.react-flow__connection .animated{stroke-dasharray:5;-webkit-animation:dashdraw .5s linear infinite;animation:dashdraw .5s linear infinite}.react-flow__connectionline{z-index:1001}.react-flow__nodes{pointer-events:none;transform-origin:0 0}.react-flow__node{position:absolute;-webkit-user-select:none;-moz-user-select:none;user-select:none;pointer-events:all;transform-origin:0 0;box-sizing:border-box;cursor:-webkit-grab;cursor:grab}.react-flow__node.dragging{cursor:-webkit-grabbing;cursor:grabbing}.react-flow__nodesselection{z-index:3;transform-origin:left top;pointer-events:none}.react-flow__nodesselection-rect{position:absolute;pointer-events:all;cursor:-webkit-grab;cursor:grab}.react-flow__handle{position:absolute;pointer-events:none;min-width:5px;min-height:5px;width:6px;height:6px;background:#1a192b;border:1px solid white;border-radius:100%}.react-flow__handle.connectionindicator{pointer-events:all;cursor:crosshair}.react-flow__handle-bottom{top:auto;left:50%;bottom:-4px;transform:translate(-50%)}.react-flow__handle-top{left:50%;top:-4px;transform:translate(-50%)}.react-flow__handle-left{top:50%;left:-4px;transform:translateY(-50%)}.react-flow__handle-right{right:-4px;top:50%;transform:translateY(-50%)}.react-flow__edgeupdater{cursor:move;pointer-events:all}.react-flow__panel{position:absolute;z-index:5;margin:15px}.react-flow__panel.top{top:0}.react-flow__panel.bottom{bottom:0}.react-flow__panel.left{left:0}.react-flow__panel.right{right:0}.react-flow__panel.center{left:50%;transform:translate(-50%)}.react-flow__attribution{font-size:10px;background:#ffffff80;padding:2px 3px;margin:0}.react-flow__attribution a{text-decoration:none;color:#999}@-webkit-keyframes dashdraw{0%{stroke-dashoffset:10}}@keyframes dashdraw{0%{stroke-dashoffset:10}}.react-flow__edgelabel-renderer{position:absolute;width:100%;height:100%;pointer-events:none;-webkit-user-select:none;-moz-user-select:none;user-select:none}.react-flow__edge.updating .react-flow__edge-path{stroke:#777}.react-flow__edge-text{font-size:10px}.react-flow__node.selectable:focus,.react-flow__node.selectable:focus-visible{outline:none}.react-flow__node-default,.react-flow__node-input,.react-flow__node-output,.react-flow__node-group{padding:10px;border-radius:3px;width:150px;font-size:12px;color:#222;text-align:center;border-width:1px;border-style:solid;border-color:#1a192b;background-color:#fff}.react-flow__node-default.selectable:hover,.react-flow__node-input.selectable:hover,.react-flow__node-output.selectable:hover,.react-flow__node-group.selectable:hover{box-shadow:0 1px 4px 1px #00000014}.react-flow__node-default.selectable.selected,.react-flow__node-default.selectable:focus,.react-flow__node-default.selectable:focus-visible,.react-flow__node-input.selectable.selected,.react-flow__node-input.selectable:focus,.react-flow__node-input.selectable:focus-visible,.react-flow__node-output.selectable.selected,.react-flow__node-output.selectable:focus,.react-flow__node-output.selectable:focus-visible,.react-flow__node-group.selectable.selected,.react-flow__node-group.selectable:focus,.react-flow__node-group.selectable:focus-visible{box-shadow:0 0 0 .5px #1a192b}.react-flow__node-group{background-color:#f0f0f040}.react-flow__nodesselection-rect,.react-flow__selection{background:#0059dc14;border:1px dotted rgba(0,89,220,.8)}.react-flow__nodesselection-rect:focus,.react-flow__nodesselection-rect:focus-visible,.react-flow__selection:focus,.react-flow__selection:focus-visible{outline:none}.react-flow__controls{box-shadow:0 0 2px 1px #00000014}.react-flow__controls-button{border:none;background:#fefefe;border-bottom:1px solid #eee;box-sizing:content-box;display:flex;justify-content:center;align-items:center;width:16px;height:16px;cursor:pointer;-webkit-user-select:none;-moz-user-select:none;user-select:none;padding:5px}.react-flow__controls-button:hover{background:#f4f4f4}.react-flow__controls-button svg{width:100%;max-width:12px;max-height:12px}.react-flow__controls-button:disabled{pointer-events:none}.react-flow__controls-button:disabled svg{fill-opacity:.4}.react-flow__minimap{background-color:#fff}.react-flow__minimap svg{display:block}.react-flow__resize-control{position:absolute}.react-flow__resize-control.left,.react-flow__resize-control.right{cursor:ew-resize}.react-flow__resize-control.top,.react-flow__resize-control.bottom{cursor:ns-resize}.react-flow__resize-control.top.left,.react-flow__resize-control.bottom.right{cursor:nwse-resize}.react-flow__resize-control.bottom.left,.react-flow__resize-control.top.right{cursor:nesw-resize}.react-flow__resize-control.handle{width:4px;height:4px;border:1px solid #fff;border-radius:1px;background-color:#3367d9;transform:translate(-50%,-50%)}.react-flow__resize-control.handle.left{left:0;top:50%}.react-flow__resize-control.handle.right{left:100%;top:50%}.react-flow__resize-control.handle.top{left:50%;top:0}.react-flow__resize-control.handle.bottom{left:50%;top:100%}.react-flow__resize-control.handle.top.left,.react-flow__resize-control.handle.bottom.left{left:0}.react-flow__resize-control.handle.top.right,.react-flow__resize-control.handle.bottom.right{left:100%}.react-flow__resize-control.line{border-color:#3367d9;border-width:0;border-style:solid}.react-flow__resize-control.line.left,.react-flow__resize-control.line.right{width:1px;transform:translate(-50%);top:0;height:100%}.react-flow__resize-control.line.left{left:0;border-left-width:1px}.react-flow__resize-control.line.right{left:100%;border-right-width:1px}.react-flow__resize-control.line.top,.react-flow__resize-control.line.bottom{height:1px;transform:translateY(-50%);left:0;width:100%}.react-flow__resize-control.line.top{top:0;border-top-width:1px}.react-flow__resize-control.line.bottom{border-bottom-width:1px;top:100%}.app{display:flex;flex-direction:column;min-height:100vh;max-height:100vh;overflow:hidden}.app.landing-mode{max-height:none;overflow:visible}.app-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-md) var(--space-lg);background:var(--bg-secondary);border-bottom:1px solid var(--border-secondary);gap:var(--space-lg);flex-shrink:0}.header-left{display:flex;align-items:center;gap:var(--space-lg);flex:1}.main-nav{display:flex;gap:var(--space-xs);background:var(--bg-tertiary);padding:4px;border-radius:var(--radius-md);border:1px solid var(--border-secondary)}.nav-btn{padding:8px 16px;font-size:.85rem;font-weight:500;color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.nav-btn:hover{color:var(--text-primary);background:var(--bg-card-hover)}.nav-btn.active{background:var(--text-primary);color:var(--bg-primary)}.nav-btn svg{margin-right:var(--space-xs);vertical-align:middle}.app-title{font-size:1.5rem;font-weight:600;color:var(--accent-primary);display:flex;align-items:center;gap:var(--space-sm)}.title-icon{color:var(--accent-primary);font-size:1.25rem}.title-icon-lucide{color:var(--accent-primary)}.app-subtitle{font-size:.875rem;color:var(--text-tertiary);font-weight:400}.header-center{display:flex;justify-content:center}.header-right{display:flex;align-items:center;justify-content:flex-end;gap:var(--space-md);flex:1}.clear-all-btn{padding:var(--space-xs) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);font-size:.8rem;transition:all var(--transition-fast)}.clear-all-btn:hover{background:var(--bearish-dim);border-color:var(--bearish);color:var(--bearish)}.clear-all-btn svg{margin-right:var(--space-xs);vertical-align:middle}.app-main{display:grid;grid-template-columns:1fr 1fr;gap:0;padding:var(--space-md) var(--space-lg);flex:1;overflow:hidden;min-height:0;position:relative}.chart-section{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-secondary);overflow:hidden;display:flex;flex-direction:column;margin-right:8px;min-height:0;height:100%}.chart-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-secondary);background:var(--bg-secondary);gap:var(--space-md);flex-shrink:0}.chart-header-right{display:flex;align-items:center;gap:var(--space-sm)}.chart-view-container{flex:1;display:flex;flex-direction:column;min-height:0;overflow:hidden}.chart-view-container>*{flex:1;min-height:0;width:100%}.view-toggle-btn{display:flex;align-items:center;gap:var(--space-xs);padding:6px 14px;background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);font-size:.8rem;font-weight:500;font-family:var(--font-primary);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap}.view-toggle-btn:hover{filter:brightness(1.1);transform:scale(1.02)}.view-toggle-btn.graph-active{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary)}.stock-search{display:flex;gap:var(--space-sm);align-items:center}.search-input-wrapper{position:relative;display:flex;align-items:center}.search-input-wrapper .search-icon{position:absolute;left:10px;color:var(--text-tertiary);pointer-events:none;transition:color var(--transition-fast)}.search-input-wrapper:focus-within .search-icon{color:var(--accent-primary)}.stock-search-input{width:200px;padding:6px 12px 6px 36px;background:var(--bg-card);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:.85rem;font-family:var(--font-mono);text-transform:uppercase;letter-spacing:1px;color:var(--text-primary)}.stock-search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow);outline:none}.stock-search-input::placeholder{text-transform:none;letter-spacing:normal;color:var(--text-tertiary)}.stock-search-btn{padding:6px 16px;background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-md);font-size:.85rem;font-weight:500;transition:all var(--transition-fast)}.stock-search-btn:hover:not(:disabled){background:var(--text-secondary)}.stock-search-btn:disabled{opacity:.5;cursor:not-allowed}.resize-handle{position:absolute;top:var(--space-md);bottom:var(--space-md);width:20px;transform:translate(-50%);cursor:col-resize;z-index:10;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.resize-handle-line{width:4px;height:100%;background:transparent;border-radius:2px;transition:all .2s ease;pointer-events:none;position:relative;display:flex;align-items:center;justify-content:center}.resize-handle-line:before{content:"";position:absolute;width:4px;height:32px;background-image:radial-gradient(circle,var(--border-primary) 1.5px,transparent 1.5px);background-size:4px 8px;background-position:center;opacity:.4;transition:all .2s ease}.resize-handle:hover .resize-handle-line{background:var(--accent-primary);opacity:.15}.resize-handle:hover .resize-handle-line:before{background-image:radial-gradient(circle,var(--accent-primary) 1.5px,transparent 1.5px);opacity:1}.resize-handle.resizing .resize-handle-line{background:var(--accent-primary);opacity:.25;width:6px}.resize-handle.resizing .resize-handle-line:before{background-image:radial-gradient(circle,var(--accent-primary) 1.5px,transparent 1.5px);opacity:1;height:48px}.analysis-panel{overflow-y:auto;display:flex;flex-direction:column;margin-left:8px;flex:1;min-height:0}.app-footer{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-lg);background:var(--bg-secondary);border-top:1px solid var(--border-secondary);font-size:.75rem;color:var(--text-tertiary);flex-shrink:0}.tech-stack{font-family:var(--font-mono);letter-spacing:.5px}.connection-status{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-xs) var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);font-size:.8rem;border:1px solid var(--border-primary)}.status-indicator{font-size:.75rem;animation:blink 1s ease-in-out infinite}.connection-status.connected .status-indicator{animation:none}.connection-status.connecting .status-indicator,.connection-status.reconnecting .status-indicator{animation:spin 1s linear infinite}@keyframes blink{50%{opacity:.5}}.status-label{color:var(--text-secondary)}.status-icon{flex-shrink:0}.status-icon.connected{color:var(--bullish)}.status-icon.disconnected{color:var(--bearish)}.live-badge{display:flex;align-items:center;gap:4px;background:var(--bullish-dim);color:var(--bullish);padding:2px 8px;border-radius:var(--radius-sm);font-weight:600;font-size:.7rem;letter-spacing:1px}.live-badge .pulse{width:6px;height:6px;background:var(--bullish);border-radius:50%;animation:pulse 1.5s ease-in-out infinite}@keyframes pulse{0%,to{transform:scale(1);opacity:1}50%{transform:scale(1.3);opacity:.7}}.api-key-input{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-md);border:1px solid var(--border-secondary)}.api-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.api-header h3{font-size:.9rem;font-weight:500;color:var(--text-secondary)}.get-key-link{font-size:.75rem;color:var(--accent-secondary)}.api-form{display:flex;flex-direction:column;gap:var(--space-sm)}.input-wrapper{position:relative;display:flex}.api-input{flex:1;padding-right:40px;font-size:.85rem}.toggle-visibility{position:absolute;right:8px;top:50%;transform:translateY(-50%);padding:4px;opacity:.6;transition:opacity var(--transition-fast)}.toggle-visibility:hover{opacity:1}.api-actions{display:flex;gap:var(--space-sm)}.connect-btn{flex:1;padding:var(--space-sm) var(--space-md);background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-fast)}.connect-btn:hover:not(:disabled){background:var(--text-secondary);transform:translateY(-1px)}.clear-btn{padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-md);color:var(--text-secondary);transition:all var(--transition-fast)}.clear-btn:hover{border-color:var(--bearish);color:var(--bearish)}.api-note{margin-top:var(--space-sm);font-size:.7rem;color:var(--text-muted);text-align:center}.interval-selector{display:flex;align-items:center;gap:var(--space-md)}.interval-label{font-size:.8rem;color:var(--text-tertiary);display:flex;align-items:center;gap:var(--space-xs)}.interval-icon{color:var(--text-muted)}.interval-buttons{display:flex;gap:2px;background:var(--bg-tertiary);padding:3px;border-radius:var(--radius-md);border:1px solid var(--border-secondary)}.interval-btn{padding:6px 12px;font-size:.75rem;font-family:var(--font-mono);color:var(--text-secondary);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.interval-btn:hover{color:var(--text-primary);background:var(--bg-card-hover)}.interval-btn.active{background:var(--text-primary);color:var(--bg-primary)}.symbol-selector{background:var(--bg-card);border-radius:var(--radius-lg);padding:var(--space-md);border:1px solid var(--border-secondary);flex:1;display:flex;flex-direction:column;min-height:0}.selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-md)}.selector-header h2{font-size:1rem;font-weight:500}.expand-btn{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:var(--bg-tertiary);border-radius:var(--radius-sm);color:var(--text-secondary);font-size:1.2rem;line-height:1;transition:all var(--transition-fast)}.expand-btn:hover{background:var(--bg-card-hover);color:var(--text-primary)}.search-form{display:flex;gap:var(--space-sm);margin-bottom:var(--space-md)}.search-input{flex:1;text-transform:uppercase;font-size:.9rem;letter-spacing:1px}.add-btn{padding:var(--space-sm) var(--space-md);background:var(--text-primary);color:var(--bg-primary);border-radius:var(--radius-md);font-weight:500;transition:all var(--transition-fast)}.add-btn:hover:not(:disabled){background:var(--text-secondary);transform:translateY(-1px)}.popular-section{margin-bottom:var(--space-md);max-height:0;overflow:hidden;transition:max-height var(--transition-normal)}.popular-section.expanded{max-height:300px}.popular-section h3,.subscribed-section h3{font-size:.75rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm)}.popular-grid{display:flex;flex-wrap:wrap;gap:var(--space-xs)}.popular-btn{padding:6px 10px;background:var(--bg-tertiary);border:1px solid var(--border-primary);border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.75rem;color:var(--text-secondary);transition:all var(--transition-fast);display:flex;align-items:center;gap:4px}.popular-btn .add-icon{color:var(--text-muted)}.popular-btn .subscribed-icon{color:var(--accent-primary)}.popular-btn:hover{border-color:var(--text-secondary);color:var(--text-primary)}.popular-btn.subscribed{background:var(--bg-card-hover);border-color:var(--text-secondary);color:var(--text-primary)}.subscribed-section{flex:1;display:flex;flex-direction:column;min-height:0}.empty-state{text-align:center;padding:var(--space-lg);color:var(--text-tertiary)}.empty-state .empty-icon{display:block;margin:0 auto var(--space-md);color:var(--text-muted);opacity:.5}.empty-state p{margin-bottom:var(--space-xs)}.empty-state .hint{font-size:.75rem;color:var(--text-muted)}.subscribed-list{display:flex;flex-direction:column;gap:var(--space-xs);overflow-y:auto;flex:1}.subscribed-item{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-sm) var(--space-md);background:var(--bg-tertiary);border:1px solid var(--border-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);position:relative}.subscribed-item:hover{background:var(--bg-card-hover);border-color:var(--border-primary)}.subscribed-item.active{border-color:var(--text-secondary);background:var(--bg-card-hover)}.item-main{display:flex;justify-content:space-between;align-items:center}.symbol-info{display:flex;flex-direction:column;gap:2px}.symbol-name{font-family:var(--font-mono);font-weight:600;font-size:.95rem;letter-spacing:1px}.symbol-fullname{font-size:.7rem;color:var(--text-muted);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:140px}.symbol-price{font-family:var(--font-mono);font-size:.85rem;color:var(--text-secondary)}.item-stats{display:flex;gap:var(--space-md)}.stat{font-size:.7rem}.stat-label{color:var(--text-muted);margin-right:4px}.stat-value{font-family:var(--font-mono);color:var(--text-secondary)}.item-actions{position:absolute;right:var(--space-sm);top:50%;transform:translateY(-50%);display:flex;gap:4px;opacity:0;transition:opacity var(--transition-fast)}.subscribed-item:hover .item-actions{opacity:1}.action-btn{padding:4px 6px;font-size:.7rem;border-radius:var(--radius-sm);transition:all var(--transition-fast)}.clear-btn:hover{background:var(--warning);background:#fbbf2433}.remove-btn:hover{background:var(--bearish-dim);color:var(--bearish)}.stock-chart{flex:1;display:flex;flex-direction:column;min-height:0;position:relative}.chart-cta-overlay{position:absolute;bottom:48px;left:50%;transform:translate(-50%);z-index:10;pointer-events:none;display:flex;justify-content:center}.chart-cta-banner{display:flex;align-items:center;gap:10px;background:#c96a30eb;color:#fff;padding:10px 18px;border-radius:8px;font-size:.875rem;font-weight:500;box-shadow:0 4px 16px #c96a3059;white-space:nowrap;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.chart-cta-icon{flex-shrink:0;opacity:.9}.chart-placeholder{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;color:var(--text-tertiary);padding:var(--space-xl)}.placeholder-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.5}.chart-placeholder h3{font-size:1.1rem;margin-bottom:var(--space-sm);color:var(--text-secondary)}.chart-placeholder p{font-size:.9rem;max-width:300px}.loading-dots{display:flex;gap:6px;margin-top:var(--space-md)}.loading-dots span{width:8px;height:8px;background:var(--text-secondary);border-radius:50%;animation:loading-bounce 1.4s ease-in-out infinite both}.loading-dots span:nth-child(1){animation-delay:-.32s}.loading-dots span:nth-child(2){animation-delay:-.16s}@keyframes loading-bounce{0%,80%,to{transform:scale(0)}40%{transform:scale(1)}}.chart-info{display:flex;align-items:center;gap:var(--space-lg);padding:var(--space-sm) var(--space-md);background:var(--bg-secondary);border-top:1px solid var(--border-secondary);font-size:.75rem}.info-item{display:flex;align-items:center;gap:var(--space-xs)}.info-item .info-icon{color:var(--text-muted);flex-shrink:0}.info-item .label{color:var(--text-muted);margin-right:6px}.info-item .value{font-family:var(--font-mono);color:var(--text-secondary)}.info-item.hint{margin-left:auto;color:var(--text-tertiary)}.trend-analysis{background:var(--bg-card);border-radius:var(--radius-lg);border:1px solid var(--border-secondary);overflow:hidden;display:flex;flex-direction:column;flex:1}.trend-analysis.bullish{border-color:var(--bullish-dim)}.trend-analysis.bearish{border-color:var(--bearish-dim)}.trend-tabs{display:flex;background:var(--bg-secondary);border-bottom:1px solid var(--border-secondary);padding:var(--space-xs);gap:var(--space-xs)}.trend-tab{flex:1;padding:10px 16px;font-size:.9rem;font-weight:500;color:var(--text-secondary);background:transparent;border-radius:var(--radius-md);transition:all var(--transition-fast)}.trend-tab:hover{color:var(--text-primary);background:var(--bg-card-hover)}.trend-tab.active{background:var(--text-primary);color:var(--bg-primary)}.trend-tab svg{margin-right:var(--space-xs);vertical-align:middle}.trend-tab-content{flex:1;overflow-y:auto;padding:var(--space-md)}.trend-header{display:flex;justify-content:space-between;align-items:center;padding:var(--space-md);border-bottom:1px solid var(--border-secondary)}.trend-header h2{font-size:1rem;font-weight:500}.trend-badge-container{display:flex;align-items:center;gap:var(--space-sm)}.trend-badge{padding:4px 10px;border-radius:var(--radius-sm);font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:var(--space-xs)}.trend-badge.bullish{background:var(--bullish-dim);color:var(--bullish)}.trend-badge.bearish{background:var(--bearish-dim);color:var(--bearish)}.clear-selection-btn{padding:4px 8px;font-size:.7rem;color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:var(--radius-sm);transition:all var(--transition-fast)}.clear-selection-btn:hover{color:var(--text-secondary);background:var(--bg-card-hover)}.clear-selection-btn svg{margin-right:2px;vertical-align:middle}.causal-exploration-btn{display:flex;align-items:center;justify-content:center;gap:var(--space-sm);width:100%;padding:var(--space-md) var(--space-lg);margin-top:var(--space-md);font-size:.95rem;font-weight:600;color:var(--text-inverse);background:linear-gradient(135deg,var(--accent-primary),var(--accent-secondary));border:none;border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-base);box-shadow:0 4px 12px #6366f14d}.causal-exploration-btn:hover:not(:disabled){box-shadow:0 6px 20px #6366f166;transform:translateY(-1px)}.causal-exploration-btn:active:not(:disabled){transform:translateY(0)}.causal-exploration-btn:disabled{opacity:.7;cursor:not-allowed}.causal-exploration-btn .loading-spinner{animation:spin 1s linear infinite}.trend-placeholder{padding:var(--space-xl) var(--space-md);text-align:center;color:var(--text-tertiary)}.trend-placeholder .placeholder-icon{font-size:3rem;margin-bottom:var(--space-md);opacity:.5}.favorites-content{display:flex;flex-direction:column;gap:var(--space-lg)}.favorites-content .popular-section{max-height:none;margin-bottom:0}.favorites-content .popular-section h3{font-size:.75rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-xs)}.section-icon{color:var(--accent-primary)}.watchlist-section{flex:1;display:flex;flex-direction:column}.watchlist-section h3{font-size:.75rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-xs)}.watchlist-list{display:flex;flex-direction:column;gap:var(--space-sm)}.watchlist-item{display:flex;flex-direction:column;gap:var(--space-xs);padding:var(--space-md);background:var(--bg-tertiary);border:none;text-align:left;font-family:inherit;font-size:inherit;color:inherit;width:100%;border:1px solid var(--border-secondary);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);position:relative}.watchlist-item:hover{background:var(--bg-card-hover);border-color:var(--border-primary)}.watchlist-item.active{border-color:var(--accent-primary);background:var(--accent-primary-glow)}.watchlist-item .item-main{display:flex;justify-content:space-between;align-items:center}.watchlist-item .symbol-info{display:flex;flex-direction:column;gap:2px}.watchlist-item .symbol-name{font-family:var(--font-mono);font-weight:600;font-size:1rem;letter-spacing:1px}.watchlist-item .symbol-fullname{font-size:.75rem;color:var(--text-muted)}.watchlist-item .symbol-price{font-family:var(--font-mono);font-size:1rem;font-weight:500;color:var(--text-primary)}.watchlist-item .item-stats{display:flex;gap:var(--space-md)}.watchlist-item .stat-value{font-family:var(--font-mono);font-size:.85rem}.watchlist-item .remove-btn{position:absolute;right:var(--space-sm);top:var(--space-sm);padding:4px 8px;font-size:.75rem;color:var(--text-tertiary);background:var(--bg-card);border-radius:var(--radius-sm);opacity:0;transition:all var(--transition-fast)}.watchlist-item:hover .remove-btn{opacity:1}.watchlist-item .remove-btn:hover{background:var(--bearish-dim);color:var(--bearish)}.watchlist-item .loading-indicator{font-size:.7rem;color:var(--text-secondary);animation:pulse 1s ease-in-out infinite}.watchlist-item .error-indicator{font-size:.7rem;color:var(--bearish);background:var(--bearish-dim);padding:1px 6px;border-radius:var(--radius-sm)}.brush-instructions{margin-top:var(--space-lg);text-align:left}.instruction{display:flex;align-items:flex-start;gap:var(--space-sm);margin-bottom:var(--space-sm);font-size:.8rem}.instruction .step{width:20px;height:20px;display:flex;align-items:center;justify-content:center;background:var(--text-primary);color:var(--bg-primary);border-radius:50%;font-size:.7rem;font-weight:600;flex-shrink:0}.trend-content{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.trend-content .trend-badge-container,.trend-content .analysis-card.price-card,.trend-content .analysis-causal-section{grid-column:1 / -1}.analysis-card:not(.price-card){padding:var(--space-sm)}.analysis-causal-section{padding-top:var(--space-xs)}.trend-badge-container{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-sm)}.analysis-card{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--space-md);border:1px solid var(--border-secondary)}.analysis-card h3{font-size:.7rem;font-weight:600;color:var(--text-muted);text-transform:none;letter-spacing:.3px;margin-bottom:var(--space-xs);display:flex;align-items:center;gap:var(--space-xs)}.card-icon{color:var(--text-muted)}.price-change-display{display:flex;align-items:baseline;gap:var(--space-sm);margin-bottom:var(--space-md)}.change-amount{font-family:var(--font-mono);font-size:1.5rem;font-weight:600}.change-percent{font-family:var(--font-mono);font-size:.9rem}.change-amount.bullish,.change-percent.bullish{color:var(--bullish)}.change-amount.bearish,.change-percent.bearish{color:var(--bearish)}.price-range{display:flex;align-items:center;justify-content:space-between;gap:var(--space-sm)}.price-point{text-align:center}.price-point .label{display:block;font-size:.7rem;color:var(--text-muted);margin-bottom:2px}.price-point .value{font-family:var(--font-mono);font-size:.9rem}.price-arrow{color:var(--text-muted);font-size:1.2rem;display:flex;align-items:center}.extremes-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-sm)}.extreme{text-align:center;padding:var(--space-sm);background:var(--bg-card);border-radius:var(--radius-sm)}.extreme-icon{display:block;margin:0 auto 4px}.extreme-icon.bullish{color:var(--bullish)}.extreme-icon.bearish{color:var(--bearish)}.extreme .label{display:block;font-size:.65rem;color:var(--text-muted);margin-bottom:2px}.extreme .value{font-family:var(--font-mono);font-size:.85rem}.extreme.high .value{color:var(--bullish)}.extreme.low .value{color:var(--bearish)}.volume-stats{display:flex;flex-direction:column;gap:var(--space-sm)}.volume-stat{display:flex;justify-content:space-between;align-items:center}.volume-stat .label{font-size:.8rem;color:var(--text-tertiary)}.volume-stat .value{font-family:var(--font-mono);font-size:.85rem}.volatility-display{text-align:center}.volatility-value{margin-bottom:var(--space-sm)}.volatility-value .number{font-family:var(--font-mono);font-size:1.25rem;font-weight:600;color:var(--warning)}.volatility-value .label{display:block;font-size:.7rem;color:var(--text-muted);margin-top:2px}.volatility-bar{height:6px;background:var(--bg-card);border-radius:3px;overflow:hidden;margin-bottom:var(--space-xs)}.volatility-fill{height:100%;background:linear-gradient(90deg,var(--bullish),var(--warning),var(--bearish));border-radius:3px;transition:width var(--transition-normal)}.volatility-percent{font-size:.7rem;color:var(--text-tertiary)}.time-info{display:flex;flex-direction:column;gap:var(--space-sm)}.time-point{display:flex;justify-content:space-between;align-items:center}.time-point .label{font-size:.8rem;color:var(--text-tertiary)}.time-point .value{font-family:var(--font-mono);font-size:.8rem}.time-summary{text-align:center;padding-top:var(--space-sm);border-top:1px solid var(--border-secondary)}.candle-count{font-size:.75rem;color:var(--text-muted)}.global-error-banner{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-lg);background:var(--bearish-dim);border-bottom:1px solid var(--bearish);color:var(--bearish)}.global-error-banner .error-message{font-size:.85rem}.global-error-banner .dismiss-btn{background:transparent;color:var(--bearish);font-size:1.2rem;padding:0 var(--space-sm);opacity:.7;transition:opacity var(--transition-fast)}.global-error-banner .dismiss-btn:hover{opacity:1}.setup-banner{margin:var(--space-lg);padding:var(--space-lg);background:var(--bg-card);border:1px solid var(--warning);border-radius:var(--radius-lg);color:var(--text-primary)}.setup-banner h3{font-size:1.1rem;color:var(--warning);margin-bottom:var(--space-md)}.setup-banner p{margin-bottom:var(--space-md);color:var(--text-secondary)}.setup-banner ol{padding-left:var(--space-lg);color:var(--text-secondary)}.setup-banner li{margin-bottom:var(--space-sm);line-height:1.6}.setup-banner a{color:var(--text-secondary);text-decoration:underline}.setup-banner a:hover{color:var(--text-primary)}.setup-banner code{background:var(--bg-tertiary);padding:2px 6px;border-radius:var(--radius-sm);font-family:var(--font-mono);font-size:.85em;color:var(--text-primary)}.subscribed-item.loading{opacity:.7}.loading-indicator{font-size:.65rem;color:var(--text-secondary);animation:pulse 1s ease-in-out infinite}.error-indicator{font-size:.65rem;color:var(--bearish);background:var(--bearish-dim);padding:1px 4px;border-radius:var(--radius-sm)}.connection-status.disconnected{border-color:var(--bearish)}.connection-status.disconnected .status-indicator,.connection-status.disconnected .status-label{color:var(--bearish)}.connection-status.connected .status-indicator{color:var(--bullish)}.landing-page{flex:1;display:flex;flex-direction:column;min-height:100vh;background:radial-gradient(ellipse 80% 50% at 50% -20%,rgba(251,191,36,.08) 0%,transparent 50%),radial-gradient(ellipse 60% 40% at 90% 80%,rgba(180,100,50,.06) 0%,transparent 50%),linear-gradient(180deg,#fafafa,#f5f5f5,#efefef);position:relative;overflow:hidden}.landing-page:before{content:"";position:absolute;top:0;right:0;bottom:0;left:0;background-image:url("data:image/svg+xml,%3Csvg viewBox='0 0 256 256' xmlns='http://www.w3.org/2000/svg'%3E%3Cfilter id='noise'%3E%3CfeTurbulence type='fractalNoise' baseFrequency='0.9' numOctaves='4' stitchTiles='stitch'/%3E%3C/filter%3E%3Crect width='100%25' height='100%25' filter='url(%23noise)'/%3E%3C/svg%3E");opacity:.02;pointer-events:none;z-index:0}.landing-nav{display:flex;align-items:center;justify-content:flex-end;padding:1.5rem 3rem;position:relative;z-index:10}.landing-nav-right{display:flex}.live-indicator{display:flex;align-items:center;gap:.5rem;background:#0f0f0ff2;-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);padding:.5rem 1rem;border-radius:50px;border:1px solid rgba(200,140,80,.3);color:#e8c9a0;font-size:.85rem;font-weight:600;letter-spacing:.5px;box-shadow:0 2px 8px #0003}.live-dot{width:8px;height:8px;background:#166534;border-radius:50%;animation:pulse-live 1.5s ease-in-out infinite}@keyframes pulse-live{0%,to{opacity:1;transform:scale(1)}50%{opacity:.6;transform:scale(1.2)}}.landing-hero{flex:1;display:flex;align-items:center;justify-content:center;padding:2rem 5rem 4rem}.hero-content{display:flex;align-items:center;justify-content:space-between;gap:4rem;width:100%;max-width:1400px}.hero-left{flex:1;max-width:550px}.hero-center{text-align:center;max-width:800px}.hero-right{flex:1;position:relative;min-height:620px;max-width:700px}.hero-images{position:relative;width:100%;height:100%}.hero-image{position:absolute;border-radius:16px;box-shadow:0 25px 50px #0000001f,0 10px 20px #00000014,0 0 0 1px #0000000a;background:#fff;transition:transform .4s cubic-bezier(.2,0,.2,1),box-shadow .4s ease}.hero-image:hover{transform:translateY(-12px) scale(1.02)!important;box-shadow:0 35px 70px #00000026,0 15px 30px #0000001a,0 0 0 1px #00000005}.hero-image-1{width:460px;top:20px;right:0;z-index:3;transform:rotate(1.5deg) translateZ(0)}.hero-image-2{width:420px;top:180px;right:220px;z-index:2;transform:rotate(-2deg) translateZ(0)}.hero-image-3{width:360px;top:360px;right:60px;z-index:1;transform:rotate(.5deg) translateZ(0)}.landing-title{font-size:6.5rem;font-weight:500;line-height:1;margin-bottom:1.5rem;letter-spacing:.15em;background:linear-gradient(165deg,#dca064,#c8783c 35%,#aa5528 65%,#8c3c1e);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;z-index:1}.landing-title:before{content:"TRACE";position:absolute;top:0;left:0;right:0;background:linear-gradient(165deg,#ffc896e6,#e6965acc,#c86432b3);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;filter:blur(30px);opacity:.5;z-index:-1;pointer-events:none}.landing-subtitle{font-size:1.15rem;color:#525252;line-height:1.8;margin-bottom:2.5rem;max-width:480px;font-weight:400;letter-spacing:.01em}.landing-actions{display:flex;gap:1rem;justify-content:flex-start}.landing-btn{padding:.875rem 1.75rem;font-size:.95rem;font-weight:600;border-radius:12px;cursor:pointer;transition:all .2s cubic-bezier(.2,0,.2,1);display:inline-flex;align-items:center;gap:.5rem;letter-spacing:.02em}.landing-btn.primary{background:linear-gradient(135deg,sienna,#8b4513);color:#fff;border:none;box-shadow:0 1px 2px #0000001a,0 4px 12px #8b451340}.landing-btn.primary:hover{background:linear-gradient(135deg,#b8612f,#9a4c14);transform:translateY(-2px);box-shadow:0 2px 4px #0000001a,0 8px 24px #8b45134d}.landing-btn.secondary{background:#ffffffe6;color:#8b4513;border:1px solid rgba(139,69,19,.2);box-shadow:0 1px 2px #0000000a}.landing-btn.secondary:hover{background:#fff;color:#7a3d10;border-color:#8b45134d;transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.hero-right{display:flex;flex-direction:column;gap:1rem;min-width:320px}.metric-card{background:#fff;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);border-radius:16px;padding:1.25rem 1.5rem;display:flex;align-items:center;gap:1rem;box-shadow:0 4px 20px #00000014;border:1px solid #e5e5e5}.metric-icon{font-size:1.5rem;opacity:.6}.metric-content{flex:1;display:flex;flex-direction:column;gap:.25rem}.metric-label{font-size:.85rem;color:#666;font-weight:500}.metric-value{font-size:1.5rem;font-weight:600;color:#1a1a1a;font-family:var(--font-mono)}.metric-bar{width:100px;height:6px;background:#e5e5e5;border-radius:3px;overflow:hidden}.metric-fill{height:100%;border-radius:3px;transition:width .5s ease}.metric-fill.sentiment{background:linear-gradient(90deg,#3b82f6,#166534)}.metric-fill.risk{background:linear-gradient(90deg,#3b82f6,#f97316)}.metric-fill.confidence{background:linear-gradient(90deg,#3b82f6,#166534)}.ticker-bar{overflow:hidden;padding:.875rem 0;margin-top:auto;position:relative;background:linear-gradient(180deg,#fffffff2,#faf8f5fa);border-top:1px solid rgba(0,0,0,.06);box-shadow:0 -1px 3px #00000005}.ticker-bar:before,.ticker-bar:after{content:"";position:absolute;top:0;bottom:0;width:100px;z-index:2;pointer-events:none}.ticker-bar:before{left:0;background:linear-gradient(90deg,rgba(255,255,255,1) 0%,transparent 100%)}.ticker-bar:after{right:0;background:linear-gradient(270deg,rgba(250,248,245,1) 0%,transparent 100%)}.ticker-track{display:flex;gap:3rem;animation:ticker-scroll 50s linear infinite;width:max-content;position:relative;z-index:1;padding:0 2rem}@keyframes ticker-scroll{0%{transform:translate(0)}to{transform:translate(-50%)}}.ticker-item{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.ticker-item:after{content:"";width:3px;height:3px;background:#00000026;border-radius:50%;margin-left:1.25rem}.ticker-symbol{font-family:var(--font-mono);font-size:.75rem;font-weight:600;color:#737373;letter-spacing:.03em}.ticker-price{font-family:var(--font-mono);font-size:.875rem;font-weight:600;color:#262626}.ticker-change{font-family:var(--font-mono);font-size:.75rem;font-weight:600;display:flex;align-items:center;gap:2px;padding:.2rem .5rem;border-radius:6px}.ticker-change.positive{color:#16a34a;background:#16a34a1a}.ticker-change.negative{color:#dc2626;background:#dc262614}@media (max-width: 1200px){.landing-hero{padding:2rem 3rem 4rem}.landing-title{font-size:5rem}.hero-content{gap:3rem}.hero-image-1{width:380px}.hero-image-2{width:340px;top:140px;right:160px}.hero-image-3{width:320px;top:290px}.hero-right{min-height:540px}}@media (max-width: 992px){.landing-hero{padding:2rem}.hero-content{flex-direction:column;text-align:center}.hero-left{max-width:100%}.landing-title{font-size:4rem}.landing-subtitle{margin-left:auto;margin-right:auto}.landing-actions{justify-content:center}.hero-right{width:100%;max-width:500px;min-height:400px}.hero-images{display:flex;flex-direction:column;align-items:center;gap:1rem}.hero-image{position:relative;transform:none!important;top:auto!important;right:auto!important;width:100%!important;max-width:400px}.ticker-track{gap:2rem}}@media (max-width: 768px){.landing-nav{flex-direction:column;gap:1rem;padding:1rem}.landing-nav-center{display:none}.landing-title{font-size:3rem}.landing-subtitle{font-size:1rem}.landing-actions{flex-direction:column;width:100%}.landing-btn{width:100%}.hero-right{min-height:auto}.hero-image{max-width:320px}}.insights-content{display:flex;flex-direction:column;gap:var(--space-md)}.insights-card{background:var(--bg-tertiary);border-radius:var(--radius-md);padding:var(--space-md);border:1px solid var(--border-secondary)}.insights-card h3{font-size:.75rem;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm);display:flex;align-items:center;gap:var(--space-xs)}.insights-header{background:linear-gradient(135deg,var(--accent-primary-glow),var(--bg-tertiary));border-color:var(--accent-primary)}.insights-title{display:flex;align-items:center;gap:var(--space-sm)}.insights-title .title-icon{color:var(--accent-primary)}.insights-title h2{font-size:1rem;font-weight:600;color:var(--text-primary);margin:0}.insights-title .ticker{color:var(--accent-primary);font-family:var(--font-mono)}.causal-chain{display:flex;flex-direction:column;gap:var(--space-sm);margin-top:var(--space-md)}.chain-item{display:flex;flex-direction:column;align-items:center}.chain-node{width:100%;padding:var(--space-md);border-radius:var(--radius-md);background:var(--bg-secondary);border-left:3px solid var(--border-secondary);position:relative}.chain-node.cause{border-left-color:var(--accent-primary);background:var(--accent-primary-glow)}.chain-node.intermediate{border-left-color:var(--text-secondary)}.chain-node.effect{border-left-color:var(--bullish);background:var(--bullish-dim)}.chain-node .node-type{font-size:.65rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary);margin-bottom:var(--space-xs)}.chain-node .node-event{font-size:.9rem;color:var(--text-primary);margin:0;line-height:1.4}.chain-node .node-sources{display:flex;align-items:center;gap:var(--space-xs);margin-top:var(--space-xs);font-size:.7rem;color:var(--text-tertiary)}.chain-arrow{display:flex;flex-direction:column;align-items:center;padding:var(--space-xs) 0;color:var(--text-tertiary)}.chain-arrow .relationship{font-size:.65rem;text-transform:lowercase;font-style:italic}.confidence-display{display:flex;flex-direction:column;gap:var(--space-sm)}.confidence-badge{display:inline-flex;align-items:center;padding:var(--space-xs) var(--space-sm);border-radius:var(--radius-sm);font-size:.8rem;font-weight:600;width:fit-content}.confidence-badge.high{background:var(--bullish-dim);color:var(--bullish)}.confidence-badge.medium{background:var(--accent-primary-glow);color:var(--accent-primary)}.confidence-badge.low{background:var(--bearish-dim);color:var(--bearish)}.confidence-reasons{margin:0;padding-left:var(--space-md);font-size:.8rem;color:var(--text-secondary);line-height:1.6}.confidence-reasons li{margin-bottom:var(--space-xs)}.sources-list{display:flex;flex-direction:column;gap:var(--space-xs)}.source-item{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);text-decoration:none;color:var(--text-primary);transition:all var(--transition-fast);border:1px solid transparent}.source-item:hover{background:var(--bg-card-hover);border-color:var(--border-primary)}.source-item .source-name{font-size:.7rem;font-weight:600;color:var(--accent-primary);white-space:nowrap}.source-item .source-headline{flex:1;font-size:.8rem;color:var(--text-secondary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.source-item .external-icon{color:var(--text-tertiary);flex-shrink:0}.alternatives-toggle{display:flex;align-items:center;justify-content:space-between;width:100%;background:none;border:none;padding:0;cursor:pointer;color:var(--text-primary)}.alternatives-toggle h3{margin:0}.alternatives-list{margin-top:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.alternative-item{display:flex;justify-content:space-between;align-items:center;padding:var(--space-sm);background:var(--bg-secondary);border-radius:var(--radius-sm);font-size:.85rem}.alternative-item .alt-title{color:var(--text-primary)}.alternative-item .alt-score{font-size:.75rem;color:var(--text-tertiary);font-family:var(--font-mono)}.insights-loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center;color:var(--text-tertiary)}.insights-loading .loading-spinner{animation:spin 1s linear infinite;margin-bottom:var(--space-md);color:var(--accent-primary)}.insights-loading p{font-size:1rem;color:var(--text-primary);margin-bottom:var(--space-xs)}.insights-loading .loading-hint{font-size:.8rem}.loading-progress-container{display:flex;align-items:center;gap:var(--space-md);width:100%;max-width:300px;margin-bottom:var(--space-lg)}.loading-stage-icon{color:var(--accent-primary);flex-shrink:0}.loading-stage-icon.spinning{animation:spin-loading 1.2s linear infinite}@keyframes spin-loading{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-progress-bar{flex:1;height:6px;background:var(--bg-tertiary);border-radius:var(--radius-full);overflow:hidden}.loading-progress-fill{height:100%;background:linear-gradient(90deg,var(--accent-primary),var(--accent-secondary, var(--accent-primary)));border-radius:var(--radius-full);transition:width .3s ease-out}.loading-progress-percent{font-size:.85rem;font-weight:600;color:var(--accent-primary);min-width:40px;text-align:right}.loading-stage-message{font-size:.95rem;color:var(--text-primary);margin-bottom:var(--space-lg);min-height:1.5em}.loading-stages{display:flex;gap:var(--space-sm);flex-wrap:wrap;justify-content:center}.stage-indicator{display:flex;align-items:center;gap:4px;padding:4px 10px;font-size:.75rem;color:var(--text-tertiary);background:var(--bg-tertiary);border-radius:var(--radius-sm);border:1px solid var(--border-secondary);transition:all .2s ease}.stage-indicator.active{color:var(--accent-primary);border-color:var(--accent-primary);background:rgba(var(--accent-primary-rgb, 255, 152, 0),.1)}.stage-indicator.complete{color:var(--bullish);border-color:var(--bullish);background:rgba(var(--bullish-rgb, 34, 197, 94),.1)}.stage-indicator.complete svg{color:var(--bullish)}.insights-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:var(--space-xl);text-align:center}.insights-error .error-icon{color:var(--bearish);margin-bottom:var(--space-md)}.insights-error p{font-size:1rem;color:var(--text-primary);margin-bottom:var(--space-xs)}.insights-error .error-message{font-size:.8rem;color:var(--text-tertiary);margin-bottom:var(--space-md)}.insights-error .retry-btn{padding:var(--space-sm) var(--space-md);background:var(--accent-primary);color:#fff;border:none;border-radius:var(--radius-md);cursor:pointer;font-size:.85rem;transition:all var(--transition-fast)}.insights-error .retry-btn:hover{background:var(--accent-secondary)}.insights-placeholder{padding:var(--space-sm) var(--space-md);text-align:center;color:var(--text-tertiary)}.insights-placeholder .placeholder-icon{margin-bottom:var(--space-xs);opacity:.5}.insights-placeholder p{font-size:.9rem;color:var(--text-secondary);margin-bottom:var(--space-sm)}.insights-instructions{margin-top:var(--space-lg);text-align:left}.insights-active-indicator{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-md);background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-secondary);color:var(--text-secondary);font-size:.85rem}.insights-active-indicator .confidence-badge{margin-left:auto}.empty-state-headline{font-size:.95rem;font-weight:500;color:var(--text-secondary);margin-bottom:var(--space-md)}.insights-instructions.visual{display:flex;flex-direction:column;gap:0;margin-top:var(--space-md);width:100%;max-width:320px}.instruction-card{display:flex;align-items:center;gap:.75rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-secondary)}.instruction-card .step-icon{display:flex;align-items:center;justify-content:center;width:40px;height:40px;border-radius:var(--radius-md);background:var(--accent-primary-glow);color:var(--accent-primary);flex-shrink:0}.instruction-card .step-text{display:flex;flex-direction:column;gap:2px}.instruction-card .step-text strong{font-size:.85rem;color:var(--text-primary)}.instruction-card .step-text span{font-size:.72rem;color:var(--text-tertiary);line-height:1.4}.instruction-arrow{display:flex;justify-content:center;color:var(--text-muted);padding:.25rem 0}.brush-pulse{animation:brushPulse 2.5s ease-in-out infinite}@keyframes brushPulse{0%,to{opacity:.6;transform:scale(1)}50%{opacity:1;transform:scale(1.15);color:var(--accent-primary)}}@media (max-width: 1200px){.app-main{grid-template-columns:1fr 1fr}.stock-search-input{width:160px}}@media (max-width: 992px){.app-main{grid-template-columns:1fr;grid-template-rows:1fr 1fr}.chart-section{min-height:350px}.stock-search-input{width:140px}}@media (max-width: 768px){.app-header{flex-wrap:wrap;gap:var(--space-sm)}.header-center{order:3;flex:0 0 100%;justify-content:flex-start}.app-main{padding:var(--space-sm);gap:var(--space-sm);grid-template-rows:1fr auto}.chart-header{flex-wrap:wrap;gap:var(--space-sm)}.stock-search{order:2;flex:1 1 100%}.stock-search-input{flex:1;width:auto}}.video-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000d9;backdrop-filter:blur(8px);-webkit-backdrop-filter:blur(8px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:2rem;animation:fadeIn .3s ease}.video-modal{position:relative;max-width:1000px;width:100%;background:linear-gradient(135deg,#28231efa,#191612fa);border-radius:20px;padding:8px;box-shadow:0 30px 80px #00000080,0 15px 40px #0000004d,inset 0 1px #ffffff1a;border:1px solid rgba(180,120,60,.3);animation:modalSlideIn .4s ease}@keyframes modalSlideIn{0%{opacity:0;transform:scale(.9) translateY(20px)}to{opacity:1;transform:scale(1) translateY(0)}}.video-modal-close{position:absolute;top:-16px;right:-16px;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#b4642d,#964b1e);border:2px solid rgba(220,140,80,.5);border-radius:50%;color:#fff;cursor:pointer;transition:all .25s ease;box-shadow:0 4px 12px #0000004d,inset 0 1px #fff3;z-index:10}.video-modal-close:hover{background:linear-gradient(135deg,#c87332,#aa5a28);box-shadow:0 6px 20px #b4643266,inset 0 1px #ffffff40}.demo-video{width:100%;display:block;border-radius:14px;background:#000}@media (max-width: 768px){.video-modal-overlay{padding:1rem}.video-modal{border-radius:12px;padding:6px}.video-modal-close{top:-12px;right:-12px;width:40px;height:40px}.demo-video{border-radius:8px}}.causal-graph-container{display:flex;flex-direction:column;flex:1;min-height:0;width:100%;height:100%}.causal-graph-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-sm) var(--space-md);border-bottom:1px solid var(--border-secondary);flex-shrink:0}.causal-graph-title{display:flex;align-items:center;gap:var(--space-sm);font-size:.85rem;color:var(--text-secondary)}.causal-graph-title strong{color:var(--accent-primary);font-weight:600}.causal-graph-canvas{flex:1;min-height:0;position:relative;overflow:hidden;height:100%}.causal-graph-canvas .react-flow{background:linear-gradient(to bottom,#fafafa,#fff)!important}.causal-graph-canvas .react-flow__pane{cursor:grab}.causal-graph-canvas .react-flow__pane:active{cursor:grabbing}.causal-graph-canvas .react-flow__background{opacity:.4}.causal-node-wrapper{position:relative}.causal-handle{width:8px!important;height:8px!important;background:var(--accent-primary)!important;border:2px solid white!important;min-width:8px!important;min-height:8px!important;opacity:0;transition:all .25s ease;box-shadow:0 2px 6px #00000026}.causal-handle.react-flow__handle-left{left:-12px!important}.causal-handle.react-flow__handle-right{right:-12px!important}.causal-node-wrapper:hover .causal-handle{opacity:1;transform:scale(1.2)}.causal-node{background:var(--node-bg);border:2px solid var(--node-border);border-radius:14px;padding:16px 20px;min-width:220px;max-width:280px;cursor:pointer;transition:all .25s cubic-bezier(.4,0,.2,1);box-shadow:0 2px 8px #0000000a,0 1px 3px #0000000f}.causal-node:hover{box-shadow:0 4px 16px #00000014,0 2px 6px #0000001a;transform:translateY(-2px);border-color:var(--node-color)}.causal-node.selected{box-shadow:0 0 0 3px var(--node-color),0 4px 20px #0000001f;transform:translateY(-2px)}.causal-node-header{display:flex;align-items:center;gap:8px;margin-bottom:10px}.causal-node-icon{width:26px;height:26px;border-radius:8px;background:#fff;display:flex;align-items:center;justify-content:center;color:var(--node-color);flex-shrink:0;box-shadow:0 1px 3px #00000014}.causal-node-type{font-size:.7rem;font-weight:650;text-transform:uppercase;letter-spacing:.8px;color:var(--node-color);opacity:.9}.causal-node-event{font-size:.875rem;line-height:1.5;color:var(--text-primary);margin:0;font-weight:450}.causal-node-sources{display:flex;align-items:center;gap:5px;margin-top:10px;padding-top:10px;border-top:1px solid rgba(0,0,0,.06);font-size:.7rem;color:var(--text-muted);font-weight:500}.causal-edge-label{background:#fffffff2;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);border:1.5px solid var(--border-secondary);border-radius:8px;padding:4px 12px;font-size:.7rem;color:var(--text-tertiary);white-space:nowrap;cursor:pointer;transition:all .25s ease;box-shadow:0 2px 8px #0000000f;font-weight:500}.causal-edge-label.visible{opacity:1;max-width:200px;overflow:hidden;text-overflow:ellipsis;display:flex;align-items:center;gap:6px}.edge-weight{font-size:.6rem;font-weight:600;color:var(--accent-primary);background:#c96a301a;padding:1px 5px;border-radius:4px;flex-shrink:0}.causal-edge-label:hover,.causal-edge-label.selected{border-color:var(--accent-primary);color:var(--accent-primary);background:var(--accent-primary-glow);transform:scale(1.05);box-shadow:0 4px 12px #0000001a}.causal-graph-legend-panel{margin:var(--space-sm)!important}.causal-graph-legend{background:var(--bg-card);border:1px solid var(--border-secondary);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);display:flex;gap:var(--space-md);box-shadow:var(--shadow-sm)}.legend-item{display:flex;align-items:center;gap:5px;font-size:.65rem;color:var(--text-tertiary)}.legend-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.causal-detail-panel{position:absolute;top:0;right:0;bottom:0;width:280px;background:var(--bg-card);border-left:1px solid var(--border-secondary);padding:var(--space-md);overflow-y:auto;z-index:10;box-shadow:-4px 0 12px #0000000f}.causal-detail-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-md)}.causal-detail-header h3{font-size:.9rem;font-weight:600;color:var(--text-primary)}.causal-detail-close{width:28px;height:28px;display:flex;align-items:center;justify-content:center;border-radius:var(--radius-sm);color:var(--text-tertiary);transition:all var(--transition-fast)}.causal-detail-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.causal-detail-type{display:flex;align-items:center;gap:6px;font-size:.7rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-bottom:var(--space-sm)}.causal-detail-event{font-size:.8rem;line-height:1.5;color:var(--text-primary);margin-bottom:var(--space-md)}.causal-detail-section h4{display:flex;align-items:center;gap:6px;font-size:.75rem;font-weight:600;color:var(--text-secondary);margin-bottom:var(--space-sm)}.causal-detail-sources{display:flex;flex-direction:column;gap:6px}.causal-detail-source{display:flex;flex-direction:column;gap:2px;padding:8px 10px;border-radius:var(--radius-sm);background:var(--bg-secondary);text-decoration:none;transition:all var(--transition-fast);position:relative}.causal-detail-source:hover{background:var(--bg-tertiary)}.causal-detail-source .source-name{font-size:.65rem;font-weight:600;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.3px}.causal-detail-source .source-headline{font-size:.72rem;color:var(--text-primary);line-height:1.4}.causal-detail-source .source-link-icon{position:absolute;top:8px;right:8px;color:var(--text-muted)}.causal-detail-relationship{font-size:.85rem;font-style:italic;color:var(--accent-primary);padding:var(--space-md);background:var(--accent-primary-glow);border-radius:var(--radius-md);text-align:center}.causal-graph-reset-panel{margin:var(--space-sm)!important}.causal-reset-zoom{display:flex;align-items:center;justify-content:center;width:32px;height:32px;border-radius:var(--radius-sm);background:var(--bg-card);border:1px solid var(--border-secondary);color:var(--text-tertiary);cursor:pointer;box-shadow:var(--shadow-sm);transition:all var(--transition-fast)}.causal-reset-zoom:hover{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--accent-primary)}.causal-graph-confidence{display:flex;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);border-top:1px solid var(--border-secondary);font-size:.7rem;color:var(--text-tertiary);flex-shrink:0}.causal-graph-confidence ul{list-style:none;display:flex;flex-wrap:wrap;gap:4px 12px;margin:0;padding:0}.causal-graph-confidence li:before{content:"·";margin-right:4px;color:var(--text-muted)}.causal-graph-alternatives{padding:6px var(--space-md);border-top:1px solid var(--border-secondary);flex-shrink:0}.alt-label{display:flex;align-items:center;gap:5px;font-size:.7rem;color:var(--text-muted)}*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg-primary: #f5f5f5;--bg-secondary: #ebebeb;--bg-tertiary: #e0e0e0;--bg-card: #ffffff;--bg-card-hover: #fafafa;--accent-primary: #c96a30;--accent-primary-glow: rgba(201, 106, 48, .18);--accent-secondary: #e07830;--accent-tertiary: #f0a060;--bullish: #166534;--bullish-dim: rgba(22, 101, 52, .12);--bearish: #991b1b;--bearish-dim: rgba(153, 27, 27, .12);--warning: #b45309;--info: #1d4ed8;--text-primary: #1f1f1f;--text-secondary: #4a4a4a;--text-tertiary: #6b6b6b;--text-muted: #8a8a8a;--border-primary: #d4d4d4;--border-secondary: #e5e5e5;--border-accent: rgba(201, 106, 48, .25);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .08);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-glow: 0 0 20px var(--accent-primary-glow);--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--radius-sm: 4px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--transition-fast: .15s ease;--transition-normal: .25s ease;--transition-slow: .4s ease;--font-display: "Space Grotesk", ui-sans-serif, system-ui, sans-serif;--font-mono: "IBM Plex Mono", ui-monospace, monospace}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-display);background:var(--bg-primary);color:var(--text-primary);line-height:1.5;min-height:100vh;overflow-x:hidden}body:has(.landing-page){background:transparent}body:before{content:"";position:fixed;top:0;left:0;right:0;bottom:0;background:linear-gradient(180deg,#f5f5f5,#ebebeb);pointer-events:none;z-index:-1}body:has(.landing-page):before{display:none}#root{min-height:100vh}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:var(--radius-sm)}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:var(--accent-primary);color:#fff}a{color:var(--accent-secondary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-tertiary)}button{font-family:var(--font-display);cursor:pointer;border:none;background:none;font-size:inherit;color:inherit}button:disabled{opacity:.5;cursor:not-allowed}input{font-family:var(--font-mono);font-size:inherit;background:var(--bg-tertiary);border:1px solid var(--border-primary);color:var(--text-primary);border-radius:var(--radius-md);padding:var(--space-sm) var(--space-md);transition:all var(--transition-fast)}input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-primary-glow)}input::placeholder{color:var(--text-tertiary)}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important;scroll-behavior:auto!important}}.will-change-transform{will-change:transform}.will-change-opacity{will-change:opacity}svg.lucide{flex-shrink:0;vertical-align:middle}.icon-bullish,.trend-icon.bullish,.extreme-icon.bullish{color:var(--bullish)}.icon-bearish,.trend-icon.bearish,.extreme-icon.bearish{color:var(--bearish)}.icon-muted{color:var(--text-muted)}.icon-accent{color:var(--accent-primary)}.icon-left{margin-right:var(--space-xs)}.icon-right{margin-left:var(--space-xs)}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.loading-spinner{animation:spin 1s linear infinite}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.shimmer{background:linear-gradient(90deg,var(--bg-secondary) 25%,var(--bg-tertiary) 50%,var(--bg-secondary) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.skeleton{background:var(--bg-secondary);border-radius:var(--radius-md);position:relative;overflow:hidden}.skeleton:after{content:"";position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 25%,rgba(255,255,255,.4) 50%,transparent 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.pulse{animation:pulse 2s ease-in-out infinite}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.fade-in{animation:fadeIn .3s ease-out forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .3s ease-out forwards}@keyframes slideInRight{0%{opacity:0;transform:translate(20px)}to{opacity:1;transform:translate(0)}}.slide-in-right{animation:slideInRight .3s ease-out forwards}@keyframes scaleIn{0%{opacity:0;transform:scale(.95)}to{opacity:1;transform:scale(1)}}.scale-in{animation:scaleIn .3s ease-out forwards}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-5px)}}.bounce{animation:bounce 1.5s ease-in-out infinite}@keyframes glowPulse{0%,to{box-shadow:0 0 0 transparent}50%{box-shadow:var(--shadow-glow)}}.glow-pulse{animation:glowPulse 2s ease-in-out infinite}
