.fear-gauge-inline{display:flex;align-items:center;gap:8px;margin-left:auto;margin-right:16px}.fear-gauge-bars{display:flex;gap:2px;align-items:center}.fear-gauge-bar{width:5px;height:8px;border-radius:1px;transition:background-color .3s ease}.fear-gauge-bar.filled[data-zone=green]{background-color:#10b981}.fear-gauge-bar.empty[data-zone=green]{background-color:#10b98126}.fear-gauge-bar.filled[data-zone=red]{background-color:#ef4444}.fear-gauge-bar.empty[data-zone=red]{background-color:#ef444426}.fear-gauge-sentiment{font-size:13px;font-weight:500;min-width:70px;transition:color .3s ease}.fear-gauge-sentiment[data-zone=green]{color:#10b981}.fear-gauge-sentiment[data-zone=red]{color:#ef4444}body.dark-mode .fear-gauge-bar.empty[data-zone=green]{background-color:#10b98133}body.dark-mode .fear-gauge-bar.empty[data-zone=red]{background-color:#ef444433}body.dark-mode .fear-gauge-sentiment[data-zone=green]{color:#34d399}body.dark-mode .fear-gauge-sentiment[data-zone=red]{color:#f87171}@media (max-width: 768px){.fear-gauge-inline{gap:6px;margin-right:12px}.fear-gauge-bar{width:4px;height:6px;border-radius:1px}.fear-gauge-bars{gap:1.5px}.fear-gauge-sentiment{font-size:12px;min-width:60px}}@media (max-width: 480px){.fear-gauge-bar{width:3px;height:6px}.fear-gauge-sentiment{font-size:11px;min-width:50px}}.company-expanded-view{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;padding:20px;margin:12px 0;animation:expandDown .2s ease-out;position:relative}@keyframes expandDown{0%{opacity:0;transform:translateY(-10px)}to{opacity:1;transform:translateY(0)}}.company-expanded-view .expanded-header{display:flex;flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:16px;padding-bottom:12px;border-bottom:1px solid var(--border-color)}.company-expanded-view .expanded-title{display:flex;flex-direction:column;gap:4px}.company-expanded-view .expanded-ticker{font-size:20px;font-weight:600;color:var(--text-primary)}.company-expanded-view .expanded-name{font-size:16px;color:var(--text-secondary)}.company-expanded-view .expanded-actions{display:flex;width:100%;justify-content:space-between;gap:12px;align-items:center;flex-wrap:wrap}.company-expanded-view .expanded-body{padding:8px 0}.company-expanded-view .loading-details{text-align:center;padding:20px;color:var(--text-secondary)}.company-expanded-view .no-description{text-align:center;padding:20px;color:var(--text-secondary);font-style:italic}.company-expanded-view .details-section{margin-bottom:20px}.company-expanded-view .details-section h4{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.company-expanded-view .details-section p{font-size:14px;line-height:1.6;color:var(--text-secondary);margin:0}.company-expanded-view .details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin-top:16px}.company-expanded-view .detail-item{display:flex;flex-direction:column;gap:4px}.company-expanded-view .detail-label{font-size:12px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px}.company-expanded-view .detail-value{font-size:14px;color:var(--text-primary);font-weight:500}.company-expanded-view .detail-value.positive{color:var(--positive-color)}.company-expanded-view .detail-value.negative{color:var(--negative-color)}.company-expanded-view .earnings-info{background:var(--background-tertiary);padding:12px;border-radius:6px}.company-expanded-view .earnings-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin-top:8px}.company-expanded-view .view-company-btn{padding:6px 10px;background:var(--accent-primary);color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s;font-weight:500;white-space:nowrap;flex:1;min-width:fit-content;height:36px;display:flex;align-items:center;justify-content:center;line-height:1}.company-expanded-view .view-company-btn:hover{background:var(--accent-primary-hover, #1a73e8);transform:translateY(-1px)}.company-expanded-view .ask-modelalpha-btn{padding:6px 10px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;justify-content:center;gap:6px;font-weight:500;white-space:nowrap;flex:1;min-width:fit-content;height:36px;line-height:1}.company-expanded-view .ask-modelalpha-btn:hover{background:linear-gradient(135deg,#764ba2,#667eea);transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.company-expanded-view .ask-modelalpha-btn svg{width:16px;height:16px;flex-shrink:0}.company-expanded-view .ask-modelalpha-btn svg path:last-child{fill:gold;stroke:gold}.company-expanded-view .close-details{position:absolute;top:12px;right:12px;padding:4px 8px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:16px;cursor:pointer;transition:all .2s;width:28px;height:28px;display:flex;align-items:center;justify-content:center;z-index:10}.company-expanded-view .close-details:hover{background:var(--background-hover);color:var(--text-primary);border-color:var(--border-hover)}.company-expanded-view.gainer{border-left:3px solid var(--positive-color)}.company-expanded-view.loser{border-left:3px solid var(--negative-color)}.company-expanded-view.earnings{border-left:3px solid var(--accent-primary)}@media (max-width: 768px){.company-expanded-view{padding:16px;margin:8px 0}.company-expanded-view .expanded-actions{flex-direction:column;width:50%;gap:8px;align-items:stretch;margin:0 auto}.company-expanded-view .view-company-btn,.company-expanded-view .ask-modelalpha-btn{min-height:40px}.company-expanded-view .details-grid{grid-template-columns:1fr 1fr;gap:12px}.company-expanded-view .earnings-details-grid{grid-template-columns:1fr}.company-expanded-view .close-details{top:8px;right:8px}}.edit-model-holdings-view{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-primary, #ffffff)}body.dark-mode .edit-model-holdings-view{background:var(--bg-primary-dark, #1a1a1a)}.edit-holdings-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color, #e5e7eb);background:var(--bg-secondary, #f9fafb);flex-shrink:0}body.dark-mode .edit-holdings-header{background:var(--bg-secondary-dark, #2a2a2a);border-bottom-color:var(--border-color-dark, #444)}.edit-holdings-header h2{font-size:18px;font-weight:700;color:var(--text-primary, #111827);margin:0;flex:1;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}body.dark-mode .edit-holdings-header h2{color:var(--text-primary-dark, #f9fafb)}.edit-holdings-header .close-btn{background:none;border:none;font-size:28px;color:var(--text-secondary, #6b7280);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease;flex-shrink:0}.edit-holdings-header .close-btn:hover{background:var(--bg-hover, #f3f4f6)}body.dark-mode .edit-holdings-header .close-btn{color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .edit-holdings-header .close-btn:hover{background:var(--bg-hover-dark, #3a3a3a)}.error-banner{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fef2f2;border-bottom:1px solid #fecaca;color:#991b1b;font-size:14px;flex-shrink:0}body.dark-mode .error-banner{background:#4c1d1d;border-bottom-color:#7f1d1d;color:#fca5a5}.error-banner .error-icon{font-size:18px}.error-banner .error-close{margin-left:auto;background:none;border:none;font-size:20px;color:inherit;cursor:pointer;padding:0}.edit-holdings-body{flex:1;overflow-y:auto;padding:20px;display:flex;flex-direction:column;gap:24px}.search-section{position:relative}.search-input-container{position:relative;display:flex;align-items:center;gap:10px;background:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:0 16px;transition:border-color .2s ease}.search-input-container:focus-within{border-color:var(--primary-color, #3b82f6)}body.dark-mode .search-input-container{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}body.dark-mode .search-input-container:focus-within{border-color:var(--primary-color-dark, #60a5fa)}.search-icon{font-size:20px;color:var(--text-secondary, #6b7280)}body.dark-mode .search-icon{color:var(--text-secondary-dark, #9ca3af)}.search-input{flex:1;border:none;background:transparent;padding:14px 0;font-size:16px;color:var(--text-primary, #111827);outline:none}.search-input::placeholder{color:var(--text-secondary, #9ca3af)}body.dark-mode .search-input{color:var(--text-primary-dark, #f9fafb)}body.dark-mode .search-input::placeholder{color:var(--text-secondary-dark, #6b7280)}.search-loading{font-size:18px}.search-results{position:absolute;top:calc(100% + 8px);left:0;right:0;background:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;box-shadow:0 4px 12px #0000001a;max-height:300px;overflow-y:auto;z-index:100}body.dark-mode .search-results{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);box-shadow:0 4px 12px #0000004d}.search-result-item{width:100%;background:none;border:none;padding:12px 16px;text-align:left;cursor:pointer;transition:background .2s ease;border-bottom:1px solid var(--border-color, #e5e7eb)}.search-result-item:last-child{border-bottom:none}.search-result-item:hover{background:var(--bg-hover, #f3f4f6)}body.dark-mode .search-result-item{border-bottom-color:var(--border-color-dark, #444)}body.dark-mode .search-result-item:hover{background:var(--bg-hover-dark, #3a3a3a)}.result-main{display:flex;align-items:center;gap:8px;margin-bottom:4px}.result-main strong{color:var(--text-primary, #111827);font-size:15px}body.dark-mode .result-main strong{color:var(--text-primary-dark, #f9fafb)}.result-name{color:var(--text-secondary, #6b7280);font-size:14px}body.dark-mode .result-name{color:var(--text-secondary-dark, #9ca3af)}.result-meta{display:flex;align-items:center;gap:8px;font-size:12px;color:var(--text-secondary, #9ca3af)}body.dark-mode .result-meta{color:var(--text-secondary-dark, #6b7280)}.result-type,.result-exchange{padding:2px 6px;background:var(--bg-secondary, #f3f4f6);border-radius:4px}body.dark-mode .result-type,body.dark-mode .result-exchange{background:var(--bg-hover-dark, #3a3a3a)}.holdings-list-section{display:flex;flex-direction:column;gap:12px}.section-title{font-size:16px;font-weight:600;color:var(--text-primary, #111827);margin:0}body.dark-mode .section-title{color:var(--text-primary-dark, #f9fafb)}.empty-holdings{padding:40px 20px;text-align:center;color:var(--text-secondary, #6b7280);background:var(--bg-secondary, #f9fafb);border-radius:8px;border:1px dashed var(--border-color, #e5e7eb)}body.dark-mode .empty-holdings{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);color:var(--text-secondary-dark, #9ca3af)}.holdings-list{display:flex;flex-direction:column;gap:12px}.holding-entry-card{background:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:12px}body.dark-mode .holding-entry-card{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.holding-info{display:flex;flex-direction:column;gap:6px}.holding-header{display:flex;align-items:center;justify-content:space-between}.holding-ticker{font-size:16px;font-weight:700;color:var(--text-primary, #111827)}body.dark-mode .holding-ticker{color:var(--text-primary-dark, #f9fafb)}.remove-btn{background:none;border:none;font-size:18px;cursor:pointer;padding:4px;opacity:.6;transition:opacity .2s ease}.remove-btn:hover{opacity:1}.holding-details{display:flex;flex-direction:column;gap:4px}.holding-name{font-size:14px;color:var(--text-secondary, #6b7280)}body.dark-mode .holding-name{color:var(--text-secondary-dark, #9ca3af)}.holding-meta{font-size:12px;color:var(--text-secondary, #9ca3af)}body.dark-mode .holding-meta{color:var(--text-secondary-dark, #6b7280)}.percentage-control{display:flex;align-items:center;gap:8px}.percentage-input{flex:1;padding:10px 14px;font-size:16px;font-weight:600;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;background:var(--bg-primary, #ffffff);color:var(--text-primary, #111827);text-align:right;outline:none;transition:border-color .2s ease}.percentage-input:focus{border-color:var(--primary-color, #3b82f6)}body.dark-mode .percentage-input{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .percentage-input:focus{border-color:var(--primary-color-dark, #60a5fa)}.percentage-label{font-size:16px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .percentage-label{color:var(--text-primary-dark, #f9fafb)}.percentage-bar-container{width:100%;height:8px;background:var(--bg-hover, #e5e7eb);border-radius:4px;overflow:hidden}body.dark-mode .percentage-bar-container{background:var(--bg-hover-dark, #3a3a3a)}.percentage-bar{height:100%;background:var(--primary-color, #3b82f6);border-radius:4px;transition:width .3s ease}body.dark-mode .percentage-bar{background:var(--primary-color-dark, #60a5fa)}.allocation-meter-section{background:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;padding:16px;display:flex;flex-direction:column;gap:10px}body.dark-mode .allocation-meter-section{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.meter-header{display:flex;align-items:center;justify-content:space-between}.meter-label{font-size:14px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .meter-label{color:var(--text-primary-dark, #f9fafb)}.meter-value{font-size:18px;font-weight:700}.meter-value.valid{color:var(--success-color, #10b981)}.meter-value.invalid{color:var(--error-color, #ef4444)}.allocation-meter-track{width:100%;height:12px;background:var(--bg-hover, #e5e7eb);border-radius:6px;overflow:hidden}body.dark-mode .allocation-meter-track{background:var(--bg-hover-dark, #3a3a3a)}.allocation-meter-fill{height:100%;border-radius:6px;transition:width .3s ease,background .3s ease}.meter-hint{font-size:13px;font-weight:500;text-align:center}.rebalance-btn{margin-top:12px;width:100%;padding:10px 16px;background:var(--primary-color, #3b82f6);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:background .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.rebalance-btn:hover{background:#2563eb}body.dark-mode .rebalance-btn{background:var(--primary-color-dark, #60a5fa);color:#111827}body.dark-mode .rebalance-btn:hover{background:#3b82f6}.edit-holdings-footer{display:flex;align-items:center;justify-content:flex-end;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color, #e5e7eb);background:var(--bg-secondary, #f9fafb);flex-shrink:0}body.dark-mode .edit-holdings-footer{background:var(--bg-secondary-dark, #2a2a2a);border-top-color:var(--border-color-dark, #444)}.cancel-btn,.save-btn{padding:10px 20px;font-size:15px;font-weight:600;border-radius:6px;cursor:pointer;transition:all .2s ease;border:none;min-height:44px}.cancel-btn{background:var(--bg-secondary, #f3f4f6);color:var(--text-primary, #111827);border:1px solid var(--border-color, #e5e7eb)}.cancel-btn:hover:not(:disabled){background:var(--bg-hover, #e5e7eb)}body.dark-mode .cancel-btn{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .cancel-btn:hover:not(:disabled){background:var(--bg-hover-dark, #3a3a3a)}.save-btn{background:var(--primary-color, #3b82f6);color:#fff}.save-btn:hover:not(:disabled){background:#2563eb}.save-btn:disabled{opacity:.5;cursor:not-allowed}body.dark-mode .save-btn{background:var(--primary-color-dark, #60a5fa);color:#111827}body.dark-mode .save-btn:hover:not(:disabled){background:#3b82f6}@media (min-width: 768px){.edit-holdings-header h2{font-size:20px}.holdings-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:16px}.cancel-btn,.save-btn{padding:12px 24px}}.investment-section{margin:16px 20px;padding:16px;background:var(--bg-primary, #ffffff);border-radius:8px;border:1px solid var(--border-color, #e5e7eb)}body.dark-mode .investment-section{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-color-dark, #444)}.investment-display{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.investment-label{font-size:14px;color:var(--text-secondary, #6b7280);font-weight:500}body.dark-mode .investment-label{color:var(--text-secondary-dark, #9ca3af)}.investment-value{font-size:18px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .investment-value{color:var(--text-primary-dark, #f9fafb)}.investment-date-display{font-size:13px;color:var(--text-secondary, #6b7280);font-weight:400;margin-left:8px}body.dark-mode .investment-date-display{color:var(--text-secondary-dark, #9ca3af)}.investment-visibility-toggle{padding:4px 8px;font-size:16px;border:none;background:transparent;cursor:pointer;border-radius:4px;transition:all .2s;display:flex;align-items:center;justify-content:center;line-height:1}.investment-visibility-toggle:hover{background:var(--bg-hover, #e5e7eb)}body.dark-mode .investment-visibility-toggle:hover{background:var(--bg-hover-dark, #3a3a3a)}.investment-visibility-toggle:active{transform:scale(.95)}.investment-edit-btn,.investment-add-btn{margin-left:auto;padding:6px 12px;font-size:13px;border-radius:4px;border:1px solid var(--border-color, #d1d5db);background:#fff;color:var(--text-primary, #111827);cursor:pointer;transition:all .2s;font-family:inherit}.investment-add-btn{background:#ff9500;color:#fff;border-color:#ff9500;font-weight:600}.investment-edit-btn:hover,.investment-add-btn:hover{opacity:.8;transform:translateY(-1px)}body.dark-mode .investment-edit-btn{background:var(--bg-hover-dark, #3a3a3a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}.investment-editor{display:flex;flex-direction:column;gap:12px}.investment-input-group{display:flex;flex-direction:column;gap:16px}.investment-field-group{display:flex;flex-direction:column;gap:6px}.field-label{font-size:13px;font-weight:600;color:var(--text-primary, #111827);margin-bottom:2px}body.dark-mode .field-label{color:var(--text-primary-dark, #f9fafb)}.field-hint{font-size:12px;color:var(--text-secondary, #6b7280);margin-top:4px;font-style:italic}body.dark-mode .field-hint{color:var(--text-secondary-dark, #9ca3af)}.investment-date-input-group{display:flex;align-items:center;gap:8px}.date-label{font-size:13px;font-weight:500;color:var(--text-secondary, #6b7280);white-space:nowrap}body.dark-mode .date-label{color:var(--text-secondary-dark, #9ca3af)}.investment-date-input{flex:1;padding:8px 12px;font-size:14px;border:2px solid var(--border-color, #d1d5db);border-radius:6px;background:#fff;color:var(--text-primary, #111827);font-family:inherit;min-height:40px;transition:border-color .2s}.investment-date-input:focus{outline:none;border-color:#ff9500}.investment-date-input:disabled{opacity:.6;cursor:not-allowed}body.dark-mode .investment-date-input{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb);color-scheme:dark}.investment-section .input-with-prefix{display:flex;align-items:center;border:2px solid var(--border-color, #d1d5db);border-radius:6px;background:#fff;overflow:hidden;min-height:40px}.investment-section .input-with-prefix:focus-within{border-color:#ff9500}body.dark-mode .investment-section .input-with-prefix{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-color-dark, #444)}.investment-section .prefix{padding:0 12px;font-size:14px;font-weight:600;color:var(--text-secondary, #6b7280);border-right:1px solid var(--border-color, #d1d5db);background:var(--bg-secondary, #f9fafb);display:flex;align-items:center;height:100%}body.dark-mode .investment-section .prefix{color:var(--text-secondary-dark, #9ca3af);border-right-color:var(--border-color-dark, #444);background:var(--bg-hover-dark, #3a3a3a)}.investment-input{flex:1;border:none;padding:8px 12px;font-size:14px;background:transparent;color:var(--text-primary, #111827);font-family:inherit}.investment-input:focus{outline:none}.investment-input:disabled{opacity:.6;cursor:not-allowed}body.dark-mode .investment-input{color:var(--text-primary-dark, #f9fafb)}.investment-actions{display:flex;gap:8px;flex-wrap:wrap}.investment-save-btn,.investment-cancel-btn,.investment-remove-btn{padding:8px 12px;font-size:13px;border-radius:4px;border:none;cursor:pointer;transition:all .2s;font-weight:600;font-family:inherit}.investment-save-btn{background:#10b981;color:#fff}.investment-save-btn:hover:not(:disabled){background:#059669}.investment-cancel-btn{background:var(--bg-secondary, #f3f4f6);border:1px solid var(--border-color, #d1d5db);color:var(--text-primary, #111827)}.investment-cancel-btn:hover:not(:disabled){background:var(--bg-hover, #e5e7eb)}body.dark-mode .investment-cancel-btn{background:var(--bg-hover-dark, #3a3a3a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}.investment-remove-btn{background:#ef4444;color:#fff;margin-left:auto}.investment-remove-btn:hover:not(:disabled){background:#dc2626}.investment-save-btn:disabled,.investment-cancel-btn:disabled,.investment-remove-btn:disabled{opacity:.5;cursor:not-allowed}.investment-error{padding:8px 12px;background:#fef2f2;border:1px solid #fecaca;border-radius:4px;color:#991b1b;font-size:13px}body.dark-mode .investment-error{background:#4c1d1d;border-color:#7f1d1d;color:#fca5a5}@media (min-width: 640px){.investment-input-group{flex-direction:row;align-items:center}.investment-section .input-with-prefix{flex:1}.investment-actions{flex-shrink:0}}.create-model-view{display:flex;flex-direction:column;height:100%;overflow:hidden;background:var(--bg-primary, #ffffff);container-type:inline-size;container-name:create-model}body.dark-mode .create-model-view{background:var(--bg-primary-dark, #1a1a1a)}.create-model-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color, #e5e7eb);background:var(--bg-secondary, #f9fafb);flex-shrink:0}body.dark-mode .create-model-header{background:var(--bg-secondary-dark, #2a2a2a);border-bottom-color:var(--border-color-dark, #444)}.create-model-header h2{font-size:20px;font-weight:700;color:var(--text-primary, #111827);margin:0}body.dark-mode .create-model-header h2{color:var(--text-primary-dark, #f9fafb)}.create-model-header .close-btn{background:none;border:none;font-size:28px;color:var(--text-secondary, #6b7280);cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:background .2s ease}.create-model-header .close-btn:hover{background:var(--bg-hover, #f3f4f6)}body.dark-mode .create-model-header .close-btn{color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .create-model-header .close-btn:hover{background:var(--bg-hover-dark, #3a3a3a)}.create-model-view .error-banner{display:flex;align-items:center;gap:12px;padding:12px 20px;background:#fef2f2;border-bottom:1px solid #fecaca;color:#991b1b;font-size:14px;flex-shrink:0}body.dark-mode .create-model-view .error-banner{background:#4c1d1d;border-bottom-color:#7f1d1d;color:#fca5a5}.create-model-view .error-banner .error-icon{font-size:18px}.create-model-view .error-banner .error-close{margin-left:auto;background:none;border:none;font-size:20px;color:inherit;cursor:pointer;padding:0;width:24px;height:24px}.create-model-content{flex:1;overflow-y:auto;padding:20px;-webkit-overflow-scrolling:touch}.create-model-view .form-section{margin-bottom:24px}.create-model-view .form-description{font-size:15px;color:var(--text-secondary, #6b7280);margin:0 0 24px;line-height:1.6}body.dark-mode .create-model-view .form-description{color:var(--text-secondary-dark, #9ca3af)}.create-model-view .form-field{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.create-model-view .form-field label{font-size:14px;font-weight:600;color:var(--text-primary, #111827);display:flex;align-items:center;gap:8px}body.dark-mode .create-model-view .form-field label{color:var(--text-primary-dark, #f9fafb)}.create-model-view .label-hint{font-weight:400;font-size:13px;color:var(--text-secondary, #6b7280)}body.dark-mode .create-model-view .label-hint{color:var(--text-secondary-dark, #9ca3af)}.create-model-view .text-input{width:100%;padding:14px 16px;font-size:16px;border:2px solid var(--border-color, #d1d5db);border-radius:10px;background:var(--bg-primary, #ffffff);color:var(--text-primary, #111827);transition:border-color .2s ease;min-height:48px;font-family:inherit}.create-model-view .text-input:focus{outline:none;border-color:#ff9500}.create-model-view .text-input:disabled{opacity:.6;cursor:not-allowed;background:var(--bg-secondary, #f9fafb)}body.dark-mode .create-model-view .text-input{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .create-model-view .text-input:disabled{background:var(--bg-hover-dark, #3a3a3a)}.create-model-view .field-hint{font-size:13px;color:var(--text-secondary, #6b7280);line-height:1.4}body.dark-mode .create-model-view .field-hint{color:var(--text-secondary-dark, #9ca3af)}.create-model-view .input-with-prefix{display:flex;align-items:center;border:2px solid var(--border-color, #d1d5db);border-radius:10px;background:var(--bg-primary, #ffffff);overflow:hidden;min-height:48px;transition:border-color .2s ease}.create-model-view .input-with-prefix:focus-within{border-color:#ff9500}body.dark-mode .create-model-view .input-with-prefix{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.create-model-view .input-with-prefix .prefix{padding:0 12px 0 16px;font-size:16px;font-weight:600;color:var(--text-secondary, #6b7280);border-right:1px solid var(--border-color, #d1d5db);background:var(--bg-secondary, #f9fafb);display:flex;align-items:center;height:100%}body.dark-mode .create-model-view .input-with-prefix .prefix{color:var(--text-secondary-dark, #9ca3af);border-right-color:var(--border-color-dark, #444);background:var(--bg-hover-dark, #3a3a3a)}.create-model-view .number-input{flex:1;border:none;padding:14px 16px;font-size:16px;background:transparent;color:var(--text-primary, #111827);font-family:inherit}.create-model-view .number-input:focus{outline:none}.create-model-view .number-input:disabled{opacity:.6;cursor:not-allowed}body.dark-mode .create-model-view .number-input{color:var(--text-primary-dark, #f9fafb)}.create-model-view .info-box{display:flex;gap:16px;padding:16px;background:#fff7ed;border:1px solid #fed7aa;border-radius:10px;margin-top:24px}body.dark-mode .create-model-view .info-box{background:#4c3d1f;border-color:#ff9500}.create-model-view .info-icon{font-size:24px;flex-shrink:0}.create-model-view .info-content{flex:1}.create-model-view .info-content h4{font-size:15px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 10px}body.dark-mode .create-model-view .info-content h4{color:var(--text-primary-dark, #f9fafb)}.create-model-view .info-content ul{margin:0;padding-left:20px;font-size:14px;color:var(--text-secondary, #6b7280);line-height:1.8}body.dark-mode .create-model-view .info-content ul{color:var(--text-secondary-dark, #9ca3af)}.create-model-view .info-content li{margin-bottom:6px}.create-model-view .info-content strong{color:var(--text-primary, #111827);font-weight:600}body.dark-mode .create-model-view .info-content strong{color:var(--text-primary-dark, #f9fafb)}.create-model-footer{display:flex;gap:12px;padding:16px 20px;border-top:1px solid var(--border-color, #e5e7eb);background:var(--bg-secondary, #f9fafb);flex-shrink:0}body.dark-mode .create-model-footer{background:var(--bg-secondary-dark, #2a2a2a);border-top-color:var(--border-color-dark, #444)}.create-model-footer .primary-actions{display:flex;gap:12px;flex:1}.create-model-footer .cancel-btn,.create-model-footer .create-empty-btn,.create-model-footer .create-and-add-btn{padding:14px 20px;font-size:16px;font-weight:600;border-radius:10px;cursor:pointer;transition:all .2s ease;border:none;min-height:48px;white-space:nowrap}.create-model-footer .cancel-btn{background:transparent;border:2px solid var(--border-color, #d1d5db);color:var(--text-primary, #111827);flex-shrink:0}.create-model-footer .cancel-btn:hover:not(:disabled){background:var(--bg-hover, #f3f4f6)}.create-model-footer .cancel-btn:disabled{opacity:.5;cursor:not-allowed}body.dark-mode .create-model-footer .cancel-btn{border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .create-model-footer .cancel-btn:hover:not(:disabled){background:var(--bg-hover-dark, #3a3a3a)}.create-model-footer .create-empty-btn{background:var(--bg-secondary, #f3f4f6);border:2px solid var(--border-color, #d1d5db);color:var(--text-primary, #111827);flex:1}.create-model-footer .create-empty-btn:hover:not(:disabled){background:var(--bg-hover, #e5e7eb);border-color:var(--text-secondary, #6b7280)}.create-model-footer .create-empty-btn:disabled{opacity:.5;cursor:not-allowed}body.dark-mode .create-model-footer .create-empty-btn{background:var(--bg-hover-dark, #3a3a3a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .create-model-footer .create-empty-btn:hover:not(:disabled){background:var(--bg-secondary-dark, #2a2a2a)}.create-model-footer .create-and-add-btn{background:#ff9500;color:#fff;flex:1}.create-model-footer .create-and-add-btn:hover:not(:disabled){background:#e68600;transform:translateY(-1px);box-shadow:0 4px 12px #ff95004d}.create-model-footer .create-and-add-btn:active:not(:disabled){transform:translateY(0)}.create-model-footer .create-and-add-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 374px){.create-model-header{padding:12px 16px}.create-model-header h2{font-size:18px}.create-model-content{padding:16px}.create-model-footer{flex-direction:column;padding:12px 16px}.create-model-footer .primary-actions{flex-direction:column;width:100%}.create-model-footer .cancel-btn,.create-model-footer .create-empty-btn,.create-model-footer .create-and-add-btn{width:100%}}@media (max-width: 480px){.create-model-footer{flex-wrap:wrap}.create-model-footer .cancel-btn{width:100%;order:3}.create-model-footer .primary-actions{width:100%;order:1}}@container create-model (min-width: 600px){.create-model-header{padding:20px 24px}.create-model-header h2{font-size:22px}.create-model-content{padding:24px}.create-model-view .form-section,.create-model-view .info-box{max-width:600px}}@container create-model (min-width: 800px){.create-model-header h2{font-size:24px}.create-model-content{padding:32px 40px}.create-model-view .form-section,.create-model-view .info-box{max-width:700px}.create-model-footer{padding:20px 40px}}.public-model-content{display:flex;flex-direction:column;height:100%;overflow-y:auto;background:var(--bg-primary);scrollbar-width:none;-ms-overflow-style:none}.public-model-content::-webkit-scrollbar{display:none}.public-model-content.loading,.public-model-content.error{overflow:hidden}.public-model-content .back-button{position:sticky;top:0;z-index:10;padding:12px 20px;margin:16px 24px 0;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;font-size:.95rem;font-weight:600;color:var(--text);cursor:pointer;transition:all .2s;align-self:flex-start}.public-model-content .back-button:hover{background:var(--bg-tertiary);border-color:var(--primary)}.loading-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:16px}.loading-container .spinner{width:40px;height:40px;border:3px solid var(--border);border-top-color:var(--primary);border-radius:50%;animation:spin .8s linear infinite}.loading-container p{color:var(--text-secondary);font-size:1rem}.error-container{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.error-container .error-icon{font-size:3rem;margin-bottom:16px}.error-container h2{margin:0 0 12px;font-size:1.5rem;font-weight:600;color:var(--text)}.error-container p{margin:0;color:var(--text-secondary);font-size:1rem;max-width:400px}.model-header-bar{display:flex;align-items:center;justify-content:space-between;gap:16px;padding:16px 24px;margin:0 24px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px}.header-stats{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.stat-item{color:var(--text-secondary);font-size:.9rem}.stat-divider{color:var(--border)}.header-actions{display:flex;align-items:center;gap:12px}.clone-button{padding:10px 20px;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s;white-space:nowrap;box-shadow:0 2px 8px #2563eb33}.clone-button:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.clone-button:active:not(:disabled){transform:translateY(0);box-shadow:0 1px 4px #2563eb33}.clone-button:disabled{opacity:.6;cursor:not-allowed;box-shadow:none}.clone-success-badge{padding:10px 20px;background:#34c75926;color:#34c759;border-radius:8px;font-size:.95rem;font-weight:600;white-space:nowrap}.model-content{padding:24px}.model-header-section{display:flex;align-items:center;gap:12px;margin-bottom:32px}.model-title{margin:0;font-size:2rem;font-weight:700;color:var(--text)}.badge.ai-badge{padding:6px 12px;background:#007aff1a;color:var(--primary);border-radius:6px;font-size:.85rem;font-weight:600;white-space:nowrap}.performance-section,.commentary-section,.holdings-section,.disclaimer-section{margin-bottom:32px}.section-title{margin:0 0 20px;font-size:1.5rem;font-weight:600;color:var(--text)}.performance-note{margin:16px 0 0;color:var(--text-secondary);font-size:.9rem;font-style:italic}.no-data-message{padding:40px 20px;text-align:center;color:var(--text-secondary);font-size:1rem;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px}.commentary-content{padding:20px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;color:var(--text);font-size:1rem;line-height:1.6;white-space:pre-wrap}.disclaimer-section{padding:20px;background:#ff95001a;border:1px solid rgba(255,149,0,.3);border-radius:12px}.disclaimer-text{margin:0;color:var(--text-secondary);font-size:.9rem;line-height:1.5}.disclaimer-text strong{color:var(--text)}.clone-error-banner{display:flex;align-items:center;gap:12px;padding:16px 20px;margin-top:20px;background:#ff3b301a;border:1px solid rgba(255,59,48,.3);border-radius:12px;color:#ff3b30;font-size:.95rem;font-weight:500}body.dark-mode .public-model-content{background:var(--bg-primary-dark)}body.dark-mode .back-button{background:var(--bg-secondary-dark);border-color:var(--border-dark);color:var(--text-dark)}body.dark-mode .back-button:hover{background:var(--bg-tertiary-dark)}body.dark-mode .loading-container .spinner{border-color:var(--border-dark);border-top-color:var(--primary)}body.dark-mode .loading-container p,body.dark-mode .stat-item,body.dark-mode .performance-note,body.dark-mode .no-data-message,body.dark-mode .disclaimer-text{color:var(--text-secondary-dark)}body.dark-mode .error-container h2,body.dark-mode .model-title,body.dark-mode .section-title,body.dark-mode .commentary-content,body.dark-mode .disclaimer-text strong{color:var(--text-dark)}body.dark-mode .model-header-bar,body.dark-mode .commentary-content,body.dark-mode .no-data-message{background:var(--bg-secondary-dark);border-color:var(--border-dark)}body.dark-mode .stat-divider{color:var(--border-dark)}body.dark-mode .disclaimer-section{background:#ff950026}body.dark-mode .clone-error-banner{background:#ff3b3026}@media (max-width: 768px){.public-model-content .back-button{margin:0 16px}.model-header-bar{flex-direction:column;align-items:flex-start;margin:0 16px;padding:16px}.header-stats{font-size:.85rem}.header-actions{width:100%}.clone-button,.clone-success-badge{width:100%;text-align:center;justify-content:center}.model-content{padding:16px}.model-title{font-size:1.5rem}.section-title{font-size:1.25rem}}.clone-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.clone-modal{background:var(--bg-primary);border:1px solid var(--border);border-radius:12px;padding:24px;width:100%;max-width:400px;box-shadow:0 8px 32px #0003}.clone-modal h3{margin:0 0 8px;font-size:1.25rem;font-weight:600;color:var(--text)}.clone-modal p{margin:0 0 16px;color:var(--text-secondary);font-size:.95rem}.clone-modal input{width:100%;padding:12px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;font-size:1rem;color:var(--text);outline:none;transition:border-color .2s;box-sizing:border-box}.clone-modal input:focus{border-color:var(--primary)}.clone-modal input::placeholder{color:var(--text-secondary)}.modal-error{margin-top:12px;padding:10px 12px;background:#ff3b301a;border-radius:6px;color:#ff3b30;font-size:.9rem}.modal-actions{display:flex;gap:12px;margin-top:20px;justify-content:flex-end}.modal-cancel,.modal-confirm{padding:10px 20px;border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.modal-cancel{background:var(--bg-secondary);border:1px solid var(--border);color:var(--text)}.modal-cancel:hover:not(:disabled){background:var(--bg-tertiary)}.modal-confirm{background:var(--accent-primary);border:none;color:#fff}.modal-confirm:hover:not(:disabled){background:var(--accent-hover)}.modal-cancel:disabled,.modal-confirm:disabled{opacity:.6;cursor:not-allowed}body.dark-mode .clone-modal{background:var(--bg-primary-dark);border-color:var(--border-dark)}body.dark-mode .clone-modal h3{color:var(--text-dark)}body.dark-mode .clone-modal p{color:var(--text-secondary-dark)}body.dark-mode .clone-modal input{background:var(--bg-secondary-dark);border-color:var(--border-dark);color:var(--text-dark)}body.dark-mode .clone-modal input::placeholder{color:var(--text-secondary-dark)}body.dark-mode .modal-cancel{background:var(--bg-secondary-dark);border-color:var(--border-dark);color:var(--text-dark)}body.dark-mode .modal-cancel:hover:not(:disabled){background:var(--bg-tertiary-dark)}.news-card-expanded{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);overflow-y:auto;overflow-x:hidden}.news-expanded-hero{width:calc(100% - 2.5rem);max-height:240px;margin:1.25rem 1.25rem 0;overflow:hidden;border-radius:14px;background:var(--bg-secondary);box-shadow:0 2px 8px #00000014}body.dark-mode .news-expanded-hero{box-shadow:0 2px 8px #0000004d}.news-expanded-hero-image{width:100%;height:100%;object-fit:cover;display:block}.news-expanded-content{padding:1.25rem;flex:1}.news-expanded-headline{font-size:var(--font-2xl);font-weight:700;line-height:1.3;margin:0 0 .75rem;color:var(--text-primary)}.news-expanded-metadata{display:flex;align-items:center;gap:.5rem;font-size:var(--font-sm);color:var(--text-secondary);flex-wrap:wrap;margin-bottom:1.25rem}.news-expanded-separator{opacity:.5}.news-expanded-impact-badge{display:inline-block;padding:.25rem .625rem;border-radius:var(--radius-sm);font-size:.6875rem;font-weight:600;letter-spacing:.3px;text-transform:uppercase}.news-expanded-impact-badge.high{background:var(--danger-bg);color:var(--danger-text)}.news-expanded-impact-badge.medium{background:var(--warning-bg);color:var(--warning-text)}.news-expanded-impact-badge.low{background:var(--info-bg);color:var(--info-text)}.news-expanded-section{margin-bottom:1.5rem}.news-expanded-section:last-child{margin-bottom:0}.news-expanded-section-title{font-size:var(--font-base);font-weight:600;color:var(--text-primary);opacity:.6;margin:0 0 .75rem;text-transform:uppercase;font-size:.8125rem;letter-spacing:.5px}.news-expanded-summary{font-size:var(--font-base);line-height:1.6;color:var(--text-primary);margin:0}.news-expanded-tickers{display:flex;flex-wrap:wrap;gap:.375rem}.news-expanded-ticker-badge{display:inline-flex;align-items:center;padding:.375rem .75rem;background:#0596691a;color:#059669;border:none;border-radius:var(--radius-base);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base)}body.dark-mode .news-expanded-ticker-badge{background:#10b98126;color:#10b981}.news-expanded-ticker-badge:hover{background:#05966933;transform:none}body.dark-mode .news-expanded-ticker-badge:hover{background:#10b98140}.news-expanded-tags{display:flex;flex-wrap:wrap;gap:.375rem}.news-expanded-tag{display:inline-block;padding:.25rem .625rem;background:var(--bg-secondary);color:var(--text-secondary);border-radius:var(--radius-base);font-size:.8125rem;font-weight:500;opacity:.8}.news-expanded-sources{display:flex;flex-direction:column;gap:.5rem}.news-expanded-source-link{display:flex;align-items:center;justify-content:space-between;padding:.75rem;background:transparent;border:none;border-radius:var(--radius-md);text-decoration:none;color:var(--text-primary);transition:all var(--transition-fast)}.news-expanded-source-link:hover{background:var(--bg-secondary);transform:none}.news-expanded-source-content{display:flex;align-items:center;gap:.625rem;flex:1}.news-expanded-source-icon{width:16px;height:16px;color:#059669;flex-shrink:0;opacity:.7}body.dark-mode .news-expanded-source-icon{color:#10b981}.news-expanded-source-title{font-size:.875rem;font-weight:500;color:var(--text-primary)}.news-expanded-source-arrow{width:16px;height:16px;color:var(--text-secondary);flex-shrink:0;opacity:.5;transition:opacity var(--transition-fast)}.news-expanded-source-link:hover .news-expanded-source-arrow{opacity:1}.news-expanded-chat-button{display:flex;align-items:center;justify-content:center;gap:.625rem;width:100%;padding:.75rem 1.25rem;background:#0596691a;color:#059669;border:none;border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:600;cursor:pointer;transition:all var(--transition-base)}body.dark-mode .news-expanded-chat-button{background:#10b98126;color:#10b981}.news-expanded-chat-button:hover{background:#05966933}body.dark-mode .news-expanded-chat-button:hover{background:#10b98140}.news-expanded-chat-icon{width:18px;height:18px}.news-expanded-related-section{margin-top:2rem;padding-top:1.5rem;border-top:1px solid var(--border-primary);opacity:.95}.news-expanded-related-loading{display:flex;align-items:center;justify-content:center;gap:.75rem;padding:1.5rem;color:var(--text-secondary);font-size:var(--font-sm)}.news-expanded-loading-spinner{width:18px;height:18px;border:2px solid var(--border-primary);border-top-color:#059669;border-radius:50%;animation:spin .8s linear infinite}body.dark-mode .news-expanded-loading-spinner{border-top-color:#10b981}.news-expanded-related-empty{text-align:center;color:var(--text-secondary);padding:1.5rem;font-style:italic;font-size:var(--font-sm);opacity:.7}.news-expanded-related-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(240px,1fr));gap:.75rem}.news-expanded-related-card{display:flex;flex-direction:column;background:transparent;border:none;border-radius:var(--radius-md);overflow:hidden;cursor:pointer;transition:all var(--transition-fast)}.news-expanded-related-card:hover{background:var(--bg-secondary)}.news-expanded-related-image{width:100%;height:100px;overflow:hidden;background:var(--bg-secondary);border-radius:var(--radius-md)}.news-expanded-related-image img{width:100%;height:100%;object-fit:cover}.news-expanded-related-content{padding:.625rem;flex:1;display:flex;flex-direction:column;gap:.375rem}.news-expanded-related-impact{display:inline-block;padding:.1875rem .4375rem;border-radius:var(--radius-sm);font-size:.625rem;font-weight:600;text-transform:uppercase;letter-spacing:.3px;align-self:flex-start;opacity:.8}.news-expanded-related-impact.high{background:var(--danger-bg);color:var(--danger-text)}.news-expanded-related-impact.medium{background:var(--warning-bg);color:var(--warning-text)}.news-expanded-related-impact.low{background:var(--info-bg);color:var(--info-text)}.news-expanded-related-headline{font-size:.8125rem;font-weight:600;line-height:1.3;color:var(--text-primary);margin:0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}@media (max-width: 768px){.news-expanded-hero{width:calc(100% - 2rem);margin:1rem 1rem 0;max-height:200px}.news-expanded-content{padding:1rem}.news-expanded-headline{font-size:var(--font-xl)}.news-expanded-section{margin-bottom:1.25rem}.news-expanded-related-grid{grid-template-columns:1fr}.news-expanded-summary{font-size:var(--font-sm)}}.news-card-expanded::-webkit-scrollbar{width:6px}.news-card-expanded::-webkit-scrollbar-track{background:transparent}.news-card-expanded::-webkit-scrollbar-thumb{background:var(--border-primary);border-radius:3px}.news-card-expanded::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}.save-model-modal{background:var(--background-primary);border-radius:12px;width:90%;max-width:480px;box-shadow:0 10px 50px #0000004d;overflow:hidden}.save-model-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px;border-bottom:1px solid var(--border-color);background:var(--background-secondary)}.save-model-modal .modal-header h3{font-size:18px;font-weight:600;margin:0;color:var(--text-primary)}.save-model-modal .close-btn{width:28px;height:28px;border:none;background:transparent;color:var(--text-secondary);font-size:20px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.save-model-modal .close-btn:hover{background:var(--hover-background)}.save-model-modal .modal-body{padding:20px}.holdings-preview{background:var(--background-secondary);border-radius:8px;padding:12px;margin-bottom:20px}.preview-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.preview-tickers{display:flex;flex-wrap:wrap;gap:6px}.ticker-badge{padding:3px 10px;background:var(--background-primary);border:1px solid var(--border-color);border-radius:14px;font-size:12px;color:var(--text-primary);font-weight:500}.ticker-badge.more{color:var(--text-secondary);font-style:italic}.save-model-modal .form-group{margin-bottom:16px}.save-model-modal .form-group label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:8px}.save-model-modal .form-group input{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--background-primary);color:var(--text-primary);font-size:14px;transition:border-color .2s}.save-model-modal .form-group input:focus{outline:none;border-color:var(--primary-color)}.save-model-modal .form-group input:disabled{opacity:.6;cursor:not-allowed}.save-model-modal .error-message{color:var(--error-color);font-size:12px;margin-top:6px}.ai-note{display:flex;align-items:flex-start;gap:10px;padding:12px;background:var(--info-background, rgba(66, 153, 225, .1));border-radius:6px;font-size:13px;color:var(--text-secondary);line-height:1.4}.ai-note svg{flex-shrink:0;margin-top:1px;color:var(--primary-color)}.save-model-modal .modal-footer{display:flex;justify-content:flex-end;gap:10px;padding:16px 20px;border-top:1px solid var(--border-color);background:var(--background-secondary)}.save-model-modal .btn{padding:8px 16px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s;border:none}.save-model-modal .btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.save-model-modal .btn-secondary:hover:not(:disabled){background:var(--hover-background)}.save-model-modal .btn-outline{background:transparent;color:var(--primary-color);border:1px solid var(--primary-color)}.save-model-modal .btn-outline:hover:not(:disabled){background:var(--primary-light)}.save-model-modal .btn-primary{background:var(--primary-color);color:#fff}.save-model-modal .btn-primary:hover:not(:disabled){background:var(--primary-hover)}.save-model-modal .btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.save-model-modal{width:95%}.save-model-modal .modal-footer{flex-direction:column-reverse}.save-model-modal .btn{width:100%}}.model-remodel-modal{background:var(--background-primary);border-radius:12px;width:90%;max-width:700px;max-height:85vh;overflow:hidden;display:flex;flex-direction:column;box-shadow:0 10px 50px #0000004d}.model-remodel-modal .modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color);background:var(--background-secondary)}.model-remodel-modal .modal-header h2{font-size:20px;font-weight:600;margin:0;color:var(--text-primary)}.model-remodel-modal .close-btn{width:32px;height:32px;border:none;background:transparent;color:var(--text-secondary);font-size:24px;cursor:pointer;border-radius:4px;display:flex;align-items:center;justify-content:center;transition:background-color .2s}.model-remodel-modal .close-btn:hover{background:var(--hover-background)}.model-remodel-modal .modal-body{flex:1;overflow-y:auto;padding:24px}.current-holdings-summary{background:var(--background-secondary);border-radius:8px;padding:16px;margin-bottom:24px}.current-holdings-summary h3{font-size:14px;font-weight:600;color:var(--text-secondary);margin:0 0 12px;text-transform:uppercase;letter-spacing:.5px}.holdings-list{display:flex;flex-wrap:wrap;gap:8px}.holding-badge{padding:4px 12px;background:var(--background-primary);border:1px solid var(--border-color);border-radius:16px;font-size:13px;color:var(--text-primary);font-weight:500}.holding-badge.more{color:var(--text-secondary);font-style:italic}.strategy-section h3{font-size:16px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.strategy-group{margin-bottom:24px}.strategy-label{display:block;font-size:14px;font-weight:500;color:var(--text-primary);margin-bottom:10px}.radio-group,.checkbox-group{display:flex;flex-wrap:wrap;gap:8px}.radio-group.horizontal{flex-direction:row}.checkbox-group.multi-column{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:8px}.radio-pill,.checkbox-pill{position:relative;display:inline-flex;align-items:center;padding:8px 16px;background:var(--background-secondary);border:1px solid var(--border-color);border-radius:20px;cursor:pointer;transition:all .2s;font-size:14px}.radio-pill.small,.checkbox-pill.small{padding:6px 12px;font-size:13px}.radio-pill:hover,.checkbox-pill:hover{border-color:var(--primary-color)}.radio-pill input[type=radio],.checkbox-pill input[type=checkbox]{position:absolute;opacity:0;width:0;height:0}.radio-pill input[type=radio]:checked+span,.checkbox-pill input[type=checkbox]:checked+span{color:var(--primary-color);font-weight:500}.radio-pill input[type=radio]:checked~span:before,.checkbox-pill input[type=checkbox]:checked~span:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border:2px solid var(--primary-color);border-radius:20px;pointer-events:none}.strategy-select{width:100%;max-width:300px;padding:10px 12px;border:1px solid var(--border-color);border-radius:6px;background:var(--background-primary);color:var(--text-primary);font-size:14px;cursor:pointer;transition:border-color .2s}.strategy-select:focus{outline:none;border-color:var(--primary-color)}.strategy-textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:6px;background:var(--background-primary);color:var(--text-primary);font-size:14px;font-family:inherit;resize:vertical;transition:border-color .2s}.strategy-textarea:focus{outline:none;border-color:var(--primary-color)}.model-remodel-modal .modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color);background:var(--background-secondary)}.btn{padding:10px 20px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s;border:none}.btn-secondary{background:transparent;color:var(--text-secondary);border:1px solid var(--border-color)}.btn-secondary:hover{background:var(--hover-background)}.btn-primary{background:var(--primary-color);color:#fff}.btn-primary:hover{background:var(--primary-hover)}@media (max-width: 768px){.model-remodel-modal{width:95%;max-height:90vh}.model-remodel-modal .modal-header,.model-remodel-modal .modal-body{padding:16px}.checkbox-group.multi-column{grid-template-columns:repeat(auto-fill,minmax(120px,1fr))}.radio-group.horizontal{flex-direction:column}.strategy-select{max-width:100%}.model-remodel-modal .modal-footer{flex-direction:column}.btn{width:100%}}.chatstream-container{position:fixed;top:0;left:280px;right:0;bottom:0;width:calc(100vw - 280px);height:100vh;display:flex;align-items:stretch;background-color:var(--bg-primary, #ffffff);overflow:hidden;transition:left .3s ease,width .3s ease}.chatstream-container.sidebar-collapsed{left:60px;width:calc(100vw - 60px)}@media (max-width: 768px){.chatstream-container,.chatstream-container.sidebar-collapsed{left:0;width:100vw}}.chatstream-panel-left{flex:0 0 auto;height:100vh;background-color:var(--bg-primary, #ffffff);transition:width .3s ease;z-index:10;display:flex;flex-direction:column;overflow:hidden}.chatstream-panel-left.collapsed{width:60px}.chatstream-panel-left.expanded{width:280px}.panel-toggle-btn{position:absolute;top:12px;right:10px;width:30px;height:30px;border:1px solid var(--border-color, #e0e0e0);background-color:var(--btn-bg, #ffffff);border-radius:4px;cursor:pointer;display:flex;align-items:center;justify-content:center;font-size:14px;color:var(--text-primary, #333);transition:all .2s;z-index:11}.panel-toggle-btn:hover{background-color:var(--btn-hover-bg, #f0f0f0);border-color:var(--border-hover, #999)}.chatstream-panel-left .panel-content{padding:50px 15px 15px;overflow-y:auto;flex:1}.chatstream-panel-left.collapsed .panel-content{padding:50px 5px 15px}.collapsed-content{display:flex;justify-content:center;align-items:center;font-weight:700;font-size:18px}.chatstream-panel-right{position:relative;flex:0 0 auto;height:100vh;background-color:var(--bg-primary, #ffffff);border-left:1px solid var(--border-primary, #dee2e6);z-index:10;display:flex}.panel-resize-handle{position:absolute;left:0;top:0;width:12px;height:100%;cursor:ew-resize;display:flex;align-items:center;justify-content:center;z-index:1000;pointer-events:auto;background-color:transparent}.panel-resize-handle:hover .resize-handle-bar,.panel-resize-handle:active .resize-handle-bar{background-color:var(--accent-color, #007bff)}.resize-handle-bar{width:4px;height:60px;background-color:#ccc;border-radius:4px;transition:background-color .2s}.panel-resize-handle:hover{background-color:#007bff0d}.chatstream-panel-right .panel-content{padding:0 0 0 12px;overflow-y:auto;flex:1;display:flex;flex-direction:column;position:relative;z-index:1}.chatstream-panel-center{flex:1 1 auto;height:100vh;max-width:1200px;min-width:600px;margin:0 auto;padding:0 20px;background-color:var(--bg-primary, #ffffff);overflow:hidden;display:flex;flex-direction:column}.chatstream-panel-center .panel-content{flex:1;padding:20px;overflow-y:auto}.chatstream-panel-center .chat-container{padding:0!important;margin:0!important}.chatstream-panel-center .chat-messages{padding:20px 0!important;margin:0!important}.chatstream-panel-center .chat-input-container{padding:20px 0!important;margin:0 auto!important}body.dark-mode .chatstream-container{background-color:var(--bg-primary)}body.dark-mode .chatstream-panel-left,body.dark-mode .chatstream-panel-right{background-color:var(--bg-primary);border-color:var(--border-primary)}body.dark-mode .chatstream-panel-center{background-color:var(--bg-primary);border-left-color:var(--border-primary);border-right-color:var(--border-primary)}body.dark-mode .panel-toggle-btn{background-color:var(--bg-secondary);border-color:var(--border-primary);color:var(--text-primary)}body.dark-mode .panel-toggle-btn:hover{background-color:var(--hover-background);border-color:var(--border-secondary)}body.dark-mode .resize-handle-bar{background-color:var(--border-secondary)}body.dark-mode .panel-resize-handle:hover .resize-handle-bar{background-color:var(--accent-primary)}.conversation-container{width:100%;display:flex;justify-content:center}.conversation-thread{width:100%;min-width:400px;max-width:900px;display:flex;flex-direction:column;gap:20px}.message{display:flex;gap:12px;padding:16px 0}.message-avatar{width:36px;height:36px;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:700;font-size:14px;flex-shrink:0}.message-user .message-avatar{background-color:#007bff;color:#fff}.message-assistant .message-avatar{background-color:#28a745;color:#fff}.message-content{flex:1;min-width:0}.message-header{font-weight:600;font-size:14px;margin-bottom:8px;color:var(--text-secondary, #666)}.message-text{color:var(--text-primary, #333);line-height:1.6}.message-text p{margin:0 0 12px}.message-text h4{margin:16px 0 8px;color:var(--text-primary, #333);font-size:16px;font-weight:600}.message-text ul{margin:8px 0;padding-left:20px}.message-text li{margin:4px 0}.message-text code{background-color:var(--code-bg, #f4f4f4);padding:2px 6px;border-radius:3px;font-family:Courier New,monospace;font-size:14px;color:var(--code-color, #d63384)}.message-text pre{background-color:var(--code-block-bg, #f8f9fa);border:1px solid var(--border-color, #e0e0e0);border-radius:4px;padding:12px;overflow-x:auto;margin:12px 0}.message-text pre code{background-color:transparent;padding:0;color:var(--text-primary, #333);display:block;white-space:pre}body.dark-mode .message-header{color:var(--text-secondary)}body.dark-mode .message-text,body.dark-mode .message-text h4{color:var(--text-primary)}body.dark-mode .message-text code{background-color:var(--bg-secondary);color:var(--accent-primary)}body.dark-mode .message-text pre{background-color:var(--bg-tertiary);border-color:var(--border-primary)}body.dark-mode .message-text pre code{color:var(--text-primary)}.mobile-chat-header{display:none}@media (max-width: 768px){.mobile-chat-header{display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg-primary);border-bottom:1px solid var(--border-color);position:sticky;top:0;z-index:100;gap:12px}.mobile-hamburger-btn,.mobile-settings-btn{background:transparent;border:none;padding:8px;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s}.mobile-hamburger-btn:hover,.mobile-settings-btn:hover{background:var(--bg-secondary)}.mobile-hamburger-btn:active,.mobile-settings-btn:active{background:var(--bg-tertiary)}.mobile-header-title{flex:1;font-size:16px;font-weight:600;color:var(--text-primary);text-align:center;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chatstream-panel-left{display:none}.chatstream-panel-right{width:250px!important;max-width:70vw}.chatstream-panel-center{flex:1;min-width:100%;width:100%}.chatstream-panel-center .panel-content{padding:10px}.conversation-thread{min-width:300px;max-width:100%}.message{padding:12px 0}.message-avatar{width:32px;height:32px;font-size:12px}}@media (max-width: 480px){.chatstream-panel-center{min-width:100%}}.groups-empty-state{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100%;padding:60px 24px;text-align:center}.groups-empty-state svg{color:var(--text-tertiary);margin-bottom:24px;opacity:.6}.groups-empty-state h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.groups-empty-state p{font-size:15px;color:var(--text-secondary);margin:0;max-width:400px}.dark-mode .groups-empty-state svg{color:#666}.dark-mode .groups-empty-state h3{color:#f5f5f7}.dark-mode .groups-empty-state p{color:#999}.system-conversation-container{max-width:900px;margin:40px auto 20px;padding:20px;background:#f9fafb;border:1px solid var(--border-color, #e5e7eb);border-radius:8px}.system-conversation-bubble-label{font-size:14px;font-weight:600;color:var(--text-secondary, #6b7280);margin-bottom:8px;text-transform:uppercase;letter-spacing:.5px}.system-conversation-bubble-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.system-conversation-bubble-header h2{font-size:24px;font-weight:700;color:var(--text-primary, #111827);margin:0}.system-conversation-bubble-header-right{display:flex;align-items:center;gap:12px}.system-conversation-badge{font-size:12px;color:var(--text-secondary, #6b7280);background:var(--background-secondary, #f3f4f6);padding:4px 12px;border-radius:12px;white-space:nowrap}.system-conversation-content{background:transparent;border-radius:0;padding:0;box-shadow:none}.system-conversation-container>.message-role{margin-bottom:12px;display:flex;align-items:center;gap:6px}.system-conversation-container .chat-message .message-role{display:none}.system-conversation-container .market-indices-dynamic,.system-conversation-container .dynamic-movers,.system-conversation-container .dynamic-portfolios-summary,.system-conversation-container .dynamic-market-news,.system-conversation-container .dynamic-podcasts{background:#fff}.dark-mode .system-conversation-container .market-indices-dynamic,.dark-mode .system-conversation-container .dynamic-movers,.dark-mode .system-conversation-container .dynamic-portfolios-summary,.dark-mode .system-conversation-container .dynamic-market-news,.dark-mode .system-conversation-container .dynamic-podcasts{background:#1f2937}.system-conversation-questions-outside{max-width:900px;margin:16px auto 0;padding:0 20px}@media (max-width: 768px){.system-conversation-container{margin:20px auto;padding:16px}.system-conversation-bubble-header{flex-direction:column;align-items:flex-start;gap:12px}.system-conversation-bubble-header h2{font-size:20px}.system-conversation-bubble-header-right{width:100%;flex-direction:column;align-items:flex-start;gap:8px}.system-conversation-content{padding:0}}.dark-mode .system-conversation-container{background:#1a1d24;--border-color: #374151}.dark-mode .system-conversation-bubble-label{color:#9ca3af}.dark-mode .system-conversation-bubble-header{border-bottom-color:#374151}.dark-mode .system-conversation-bubble-header h2{color:#f9fafb}.dark-mode .system-conversation-badge{color:#9ca3af;background:#374151}.dark-mode .system-conversation-content{background:transparent;box-shadow:none}.pinned-model-section{padding:12px 16px 16px;border-bottom:1px solid var(--border-color);background:var(--bg-primary, #ffffff);position:sticky;top:0;z-index:100;box-shadow:0 2px 4px #0000000d}.pinned-model-banner{display:flex;align-items:center;gap:6px;margin-bottom:8px;padding:6px 12px;background:var(--bg-secondary, #f5f5f7);border:1px solid var(--border-color);border-radius:6px;font-size:11px;font-weight:600;color:var(--text-secondary)}.dark-mode .pinned-model-section{background:var(--bg-primary, #000000);border-color:var(--border-primary);box-shadow:0 2px 8px #0000004d}.dark-mode .pinned-model-banner{background:var(--bg-secondary, #1a1a1a);border-color:var(--border-primary)}.chat-centered-container{width:80%;margin:0 auto}.chat-centered-container.centered{position:absolute;top:33%;left:50%;transform:translate(-50%,-50%);width:80%;max-width:700px;margin:0}.chat-centered-container.centered .chat-input-container{position:relative;top:auto;left:auto;transform:none;width:100%;max-width:none}.chat-greeting{text-align:center;font-size:28px;font-weight:600;color:var(--text-primary);margin-bottom:24px}@media (max-width: 768px){.chat-centered-container.centered{width:90%;top:30%}.chat-greeting{font-size:24px;margin-bottom:16px}}.tier-selector-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;display:flex;align-items:center;justify-content:center;z-index:1000}.tier-selector-modal{background:var(--bg-primary, #1a1a2e);border-radius:12px;max-width:900px;width:90%;max-height:90vh;overflow-y:auto;padding:24px}.tier-selector-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:24px}.tier-selector-header h2{margin:0;color:var(--text-primary, #fff)}.close-button{background:none;border:none;color:var(--text-secondary, #888);font-size:24px;cursor:pointer}.tier-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:16px;margin-bottom:24px}.tier-card{background:var(--bg-secondary, #252540);border:2px solid var(--border-color, #3a3a5c);border-radius:8px;padding:20px;cursor:pointer;position:relative;transition:border-color .2s,transform .2s}.tier-card:hover{border-color:var(--accent-color, #6366f1)}.tier-card.current{border-color:var(--success-color, #22c55e)}.tier-card.selected{border-color:var(--accent-color, #6366f1);transform:scale(1.02)}.current-badge{position:absolute;top:-10px;right:10px;background:var(--success-color, #22c55e);color:#fff;padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.tier-card h3{margin:0 0 8px;color:var(--text-primary, #fff)}.tier-card .price{font-size:28px;font-weight:700;color:var(--accent-color, #6366f1);margin-bottom:12px}.tier-card .description{color:var(--text-secondary, #888);font-size:14px;margin-bottom:16px}.tier-card .limits{margin-bottom:16px}.tier-card .limit{display:flex;justify-content:space-between;padding:4px 0;font-size:14px;color:var(--text-secondary, #888)}.tier-card .features{list-style:none;padding:0;margin:0}.tier-card .features li{padding:4px 0;font-size:14px;color:var(--text-primary, #fff)}.tier-card .features li:before{content:"✓ ";color:var(--success-color, #22c55e)}.tier-card .select-button{width:100%;margin-top:16px;padding:10px;background:var(--accent-color, #6366f1);color:#fff;border:none;border-radius:6px;cursor:pointer;font-weight:500}.tier-card .select-button:hover{opacity:.9}.promo-section{margin-bottom:24px}.promo-section label{display:block;margin-bottom:8px;color:var(--text-secondary, #888)}.promo-section input{width:100%;max-width:300px;padding:10px;background:var(--bg-secondary, #252540);border:1px solid var(--border-color, #3a3a5c);border-radius:6px;color:var(--text-primary, #fff)}.promo-error{color:var(--error-color, #ef4444);font-size:14px;margin-top:4px;display:block}.tier-selector-footer{display:flex;justify-content:flex-end;gap:12px}.cancel-button{padding:10px 20px;background:transparent;border:1px solid var(--border-color, #3a3a5c);color:var(--text-primary, #fff);border-radius:6px;cursor:pointer}.confirm-button{padding:10px 20px;background:var(--accent-color, #6366f1);border:none;color:#fff;border-radius:6px;cursor:pointer;font-weight:500}.confirm-button:disabled{opacity:.5;cursor:not-allowed}.usage-meter{background:var(--bg-secondary, #252540);border-radius:8px;padding:16px;margin-bottom:12px}.usage-meter-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.usage-meter .label{font-weight:500;color:var(--text-primary, #fff)}.usage-meter .reset-time{font-size:12px;color:var(--text-secondary, #888)}.progress-container{height:8px;background:var(--bg-tertiary, #1a1a2e);border-radius:4px;overflow:hidden;margin-bottom:8px}.progress-bar{height:100%;border-radius:4px;transition:width .3s ease}.usage-meter.green .progress-bar{background:var(--success-color, #22c55e)}.usage-meter.yellow .progress-bar{background:var(--warning-color, #eab308)}.usage-meter.red .progress-bar{background:var(--error-color, #ef4444)}.usage-details{display:flex;justify-content:space-between;font-size:14px}.usage-details .used{color:var(--text-secondary, #888)}.usage-details .remaining{color:var(--text-primary, #fff)}.usage-details .unlimited{color:var(--success-color, #22c55e)}.upgrade-prompt{background:var(--bg-secondary, #252540);border:1px solid var(--warning-color, #eab308);border-radius:8px;padding:20px;margin-bottom:16px}.upgrade-prompt-content{text-align:center}.upgrade-icon{font-size:32px;margin-bottom:12px}.upgrade-prompt h3{margin:0 0 8px;color:var(--text-primary, #fff)}.upgrade-prompt p{color:var(--text-secondary, #888);margin:0 0 12px}.upgrade-prompt .current-plan{font-size:14px}.upgrade-actions{display:flex;justify-content:center;gap:12px;margin-top:16px}.dismiss-button{padding:10px 20px;background:transparent;border:1px solid var(--border-color, #3a3a5c);color:var(--text-primary, #fff);border-radius:6px;cursor:pointer}.upgrade-button{padding:10px 20px;background:var(--accent-color, #6366f1);border:none;color:#fff;border-radius:6px;cursor:pointer;font-weight:500}.upgrade-button:hover{opacity:.9}.subscription-status{background:var(--bg-secondary, #252540);border-radius:8px;padding:20px;margin-bottom:16px}.tier-info{display:flex;align-items:center;gap:12px;margin-bottom:12px}.tier-info h3{margin:0;color:var(--text-primary, #fff)}.tier-info .price{color:var(--text-secondary, #888)}.status-badge{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status-badge.active{background:var(--success-color, #22c55e);color:#fff}.status-badge.trialing{background:var(--accent-color, #6366f1);color:#fff}.status-badge.past-due{background:var(--error-color, #ef4444);color:#fff}.status-badge.canceled{background:var(--text-secondary, #888);color:#fff}.status-badge.free{background:var(--border-color, #3a3a5c);color:var(--text-primary, #fff)}.subscription-details{margin-bottom:16px}.subscription-details p{margin:0;font-size:14px;color:var(--text-secondary, #888)}.trial-info{color:var(--accent-color, #6366f1)!important}.past-due-warning{color:var(--error-color, #ef4444)!important}.manage-button{width:100%;padding:10px;background:var(--bg-tertiary, #1a1a2e);border:1px solid var(--border-color, #3a3a5c);color:var(--text-primary, #fff);border-radius:6px;cursor:pointer;font-weight:500;transition:background .2s}.manage-button:hover{background:var(--border-color, #3a3a5c)}.billing-dashboard{max-width:800px;margin:0 auto;padding:1.5rem}.billing-dashboard-loading{display:flex;justify-content:center;padding:3rem;color:var(--text-secondary)}.billing-dashboard-error{padding:1rem;background:#ef44441a;border:1px solid rgba(239,68,68,.3);border-radius:8px;color:#ef4444;text-align:center}.billing-usage-section{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-bottom:1.5rem}@media (max-width: 600px){.billing-usage-section{grid-template-columns:1fr}}.billing-dashboard-section{margin-bottom:2rem}.billing-dashboard-section-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.75rem}.settings-view{padding:20px;max-width:800px;margin:0 auto}.settings-container{background:var(--background-secondary);border-radius:12px;padding:24px}.settings-title{font-size:32px;font-weight:600;margin-bottom:32px;color:var(--text-primary)}.settings-section{margin-bottom:40px;padding-bottom:32px;border-bottom:1px solid var(--border-color)}.settings-section:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.settings-section-title{font-size:20px;font-weight:600;margin-bottom:20px;color:var(--text-primary)}.settings-account{display:flex;flex-direction:column;gap:16px}.user-info{display:flex;align-items:center;gap:16px;padding:16px;background:var(--background-primary);border-radius:8px}.user-avatar{width:48px;height:48px;border-radius:50%;object-fit:cover}.user-details{flex:1}.user-name{font-size:18px;font-weight:600;color:var(--text-primary);margin-bottom:4px}.user-email{font-size:14px;color:var(--text-secondary)}.sign-in-section{display:flex;flex-direction:column;gap:16px}.sign-in-prompt{font-size:16px;color:var(--text-secondary);margin:0}.settings-button{padding:12px 24px;font-size:16px;font-weight:500;border-radius:8px;border:none;cursor:pointer;transition:all .2s;display:inline-flex;align-items:center;justify-content:center;gap:8px}.google-button{background:#fff;color:#3c4043;border:1px solid #dadce0}.google-button:hover{background:#f8f9fa;box-shadow:0 1px 2px #3c40434d,0 1px 3px 1px #3c404326}.google-icon{flex-shrink:0}.logout-button{background:var(--danger-color, #dc3545);color:#fff;align-self:flex-start}.logout-button:hover{background:var(--danger-hover, #c82333)}.settings-item{display:flex;justify-content:space-between;align-items:center;padding:16px 0}.settings-item-label{display:flex;flex-direction:column;gap:4px}.settings-label{font-size:16px;font-weight:500;color:var(--text-primary)}.settings-description{font-size:14px;color:var(--text-secondary)}.theme-toggle{display:flex;gap:8px;background:var(--background-primary);padding:4px;border-radius:8px}.theme-option{padding:8px 16px;border:none;background:transparent;color:var(--text-secondary);cursor:pointer;border-radius:6px;font-size:14px;font-weight:500;transition:all .2s;display:flex;align-items:center;gap:6px}.theme-option.active{background:var(--primary-color);color:#fff}.theme-option:hover:not(.active){background:var(--hover-background)}.settings-loading{display:flex;justify-content:center;align-items:center;height:200px;font-size:16px;color:var(--text-secondary)}.settings-username-section{padding:16px;background:var(--background-primary);border-radius:8px}.settings-username-label{font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px;margin-bottom:8px}.settings-username-display{display:flex;align-items:center;justify-content:space-between}.settings-username-value{font-size:16px;font-weight:500;color:var(--text-primary)}.settings-username-edit-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;border:none;background:var(--background-secondary);color:var(--text-secondary);font-size:13px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s}.settings-username-edit-btn:hover{background:var(--hover-background);color:var(--text-primary)}.settings-username-edit{display:flex;flex-direction:column;gap:12px}.settings-username-input-row{display:flex;align-items:center;background:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;padding:0 12px;height:44px}.settings-username-input-row:focus-within{border-color:var(--primary-color)}.settings-username-prefix{font-size:16px;color:var(--text-secondary);font-weight:500}.settings-username-input{flex:1;background:none;border:none;outline:none;font-size:16px;color:var(--text-primary);font-weight:500;padding:0 4px}.settings-username-input::placeholder{color:var(--text-tertiary)}.settings-username-validation-icon{width:20px;height:20px;display:flex;align-items:center;justify-content:center}.settings-username-spinner{width:16px;height:16px;border:2px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:settings-spin .8s linear infinite}@keyframes settings-spin{to{transform:rotate(360deg)}}.settings-username-validation-icon .icon-success{color:#22c55e}.settings-username-validation-icon .icon-error{color:#ef4444}.settings-username-message{font-size:12px;padding-left:4px}.settings-username-message.available{color:#22c55e}.settings-username-message.taken,.settings-username-message.invalid{color:#ef4444}.settings-username-message.idle,.settings-username-message.checking,.settings-username-message.unchanged{color:var(--text-secondary)}.settings-username-actions{display:flex;gap:8px;justify-content:flex-end}.settings-username-cancel,.settings-username-save{padding:8px 16px;font-size:14px;font-weight:500;border-radius:6px;cursor:pointer;transition:all .2s}.settings-username-cancel{background:transparent;border:1px solid var(--border-color);color:var(--text-secondary)}.settings-username-cancel:hover:not(:disabled){background:var(--hover-background);color:var(--text-primary)}.settings-username-save{background:var(--primary-color);border:none;color:#fff}.settings-username-save:hover:not(:disabled){opacity:.9}.settings-username-save:disabled{background:var(--background-secondary);color:var(--text-tertiary);cursor:not-allowed}.settings-username-cancel:disabled{opacity:.5;cursor:not-allowed}body.dark-mode .google-button{background:#131314;color:#e3e3e3;border-color:#5f6368}body.dark-mode .google-button:hover{background:#202124}@media (max-width: 768px){.settings-view{padding:16px}.settings-container{padding:20px}.settings-title{font-size:28px}.settings-item{flex-direction:column;align-items:flex-start;gap:12px}.theme-toggle{width:100%}.theme-option{flex:1;justify-content:center}}.mobile-billing-view{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:1.5rem;background:var(--background)}.mobile-billing-container{width:100%;max-width:500px;background:var(--surface);border-radius:16px;padding:2rem;box-shadow:0 4px 20px #0000001a}.mobile-billing-header{text-align:center;margin-bottom:2rem}.mobile-billing-header h1{font-size:1.75rem;font-weight:600;color:var(--text);margin:0 0 .5rem}.mobile-billing-header p{font-size:1rem;color:var(--text-secondary);margin:0}.mobile-billing-error{display:flex;align-items:center;gap:.75rem;padding:1rem;background:#ff3b301a;border:1px solid rgba(255,59,48,.3);border-radius:12px;color:var(--error);margin-bottom:1.5rem}.mobile-billing-error svg{flex-shrink:0}.mobile-billing-content{margin-bottom:2rem}.mobile-billing-actions{display:flex;flex-direction:column;gap:1rem;margin-bottom:1.5rem}.mobile-billing-btn-primary,.mobile-billing-btn-cancel{width:100%;padding:1rem;font-size:1rem;font-weight:600;border:none;border-radius:12px;cursor:pointer;transition:all .2s ease}.mobile-billing-btn-primary{background:var(--primary);color:#fff}.mobile-billing-btn-primary:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.mobile-billing-btn-primary:disabled{opacity:.5;cursor:not-allowed}.mobile-billing-btn-cancel{background:transparent;color:var(--text-secondary);border:1px solid var(--border)}.mobile-billing-btn-cancel:hover:not(:disabled){background:var(--background)}.mobile-billing-footer{display:flex;align-items:center;justify-content:center;gap:.5rem;padding-top:1.5rem;border-top:1px solid var(--border);color:var(--text-secondary);font-size:.875rem}.mobile-billing-footer svg{flex-shrink:0}.mobile-tier-list{display:flex;flex-direction:column;gap:1rem}.mobile-tier-card{padding:1.25rem;border:2px solid var(--border);border-radius:12px;cursor:pointer;transition:all .2s ease}.mobile-tier-card:hover{border-color:var(--primary-light, #6b9bff)}.mobile-tier-card.selected{border-color:var(--primary);background:#3b82f60d}.mobile-tier-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.75rem}.mobile-tier-header h3{margin:0;font-size:1.125rem;font-weight:600;color:var(--text)}.mobile-tier-price{font-size:1.25rem;font-weight:700;color:var(--primary)}.mobile-tier-price span{font-size:.875rem;font-weight:400;color:var(--text-secondary)}.mobile-tier-description{margin:0 0 .75rem;font-size:.875rem;color:var(--text-secondary)}.mobile-tier-features{margin:0;padding:0;list-style:none}.mobile-tier-features li{position:relative;padding-left:1.25rem;font-size:.875rem;color:var(--text-secondary);margin-bottom:.375rem}.mobile-tier-features li:before{content:"";position:absolute;left:0;top:.5em;width:6px;height:6px;border-radius:50%;background:var(--primary)}.dark-mode .mobile-billing-container{box-shadow:0 4px 20px #0000004d}@media (max-width: 768px){.mobile-billing-view{padding:1rem}.mobile-billing-container{padding:1.5rem}.mobile-billing-header h1{font-size:1.5rem}}.models-view{position:fixed;top:0;left:280px;right:0;bottom:0;display:flex;flex-direction:column;height:100vh;width:calc(100vw - 280px);overflow:hidden;background:var(--bg-primary, #ffffff);transition:left .3s ease,width .3s ease}.models-view.sidebar-collapsed{left:60px;width:calc(100vw - 60px)}.models-header{display:flex;align-items:center;justify-content:space-between;padding:24px;border-bottom:1px solid var(--border)}.models-header h1{margin:0;font-size:1.75rem;font-weight:700;color:var(--text)}.models-tabs,.models-tab,.models-tab:hover,.models-tab.active{display:none}.models-controls{display:flex;align-items:center;gap:16px;padding:16px 24px;border-bottom:1px solid var(--border)}.search-container{flex:1;max-width:400px}.search-input{width:100%;padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;font-size:.95rem;color:var(--text);transition:all .2s}.search-input:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff1a}.search-input::placeholder{color:var(--text-secondary)}.filter-container{display:flex;align-items:center;gap:8px}.filter-select{padding:10px 16px;background:var(--bg-secondary);border:1px solid var(--border);border-radius:8px;font-size:.95rem;color:var(--text);cursor:pointer;transition:all .2s}.filter-select:hover{border-color:var(--primary)}.filter-select:focus{outline:none;border-color:var(--primary);box-shadow:0 0 0 3px #007aff1a}.models-content{flex:1;overflow-y:auto;padding:24px}.models-content::-webkit-scrollbar{display:none}.models-content{-ms-overflow-style:none;scrollbar-width:none}.models-loading{display:flex;align-items:center;justify-content:center;padding:60px 20px;color:var(--text-secondary);font-size:1.1rem}.models-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.models-error .error-icon{font-size:3rem;margin-bottom:16px}.models-error .error-title{margin:0 0 8px;font-size:1.5rem;font-weight:600;color:var(--text)}.models-error .error-message{margin:0 0 24px;color:var(--text-secondary);font-size:1rem}.retry-button{padding:10px 24px;background:transparent;color:var(--primary);border:2px solid var(--primary);border-radius:8px;font-size:.95rem;font-weight:600;cursor:pointer;transition:all .2s}.retry-button:hover{background:var(--primary);color:#fff}.models-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;text-align:center}.models-empty h2{margin:0 0 12px;font-size:1.5rem;font-weight:600;color:var(--text)}.models-empty p{margin:0;color:var(--text-secondary);font-size:1rem}.models-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(340px,1fr));gap:16px}.models-grid.two-column{grid-template-columns:repeat(auto-fill,minmax(480px,1fr));gap:20px}.model-card-wrapper{position:relative;transition:transform .2s}.model-card-wrapper:hover{transform:translateY(-2px)}.public-model-card{background:var(--bg-secondary);border:1px solid var(--border);border-radius:12px;padding:20px;cursor:pointer;transition:all .2s}.public-model-card:hover{border-color:var(--primary);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.public-model-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px;margin-bottom:12px}.public-model-title{margin:0;font-size:1.1rem;font-weight:600;color:var(--text);line-height:1.4;flex:1}.public-model-badge{padding:4px 10px;background:#007aff1a;color:var(--primary);border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap}.public-model-description{margin:0 0 16px;color:var(--text-secondary);font-size:.9rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.public-model-stats{display:flex;align-items:center;gap:16px;margin-bottom:12px;padding-top:12px;border-top:1px solid var(--border)}.public-model-stat{display:flex;align-items:center;gap:6px;color:var(--text-secondary);font-size:.85rem}.public-model-stat svg{opacity:.7}.public-model-footer{display:flex;align-items:center;justify-content:space-between;padding-top:8px}.public-model-date{color:var(--text-secondary);font-size:.8rem}body.dark-mode .models-view{background:var(--bg-primary-dark, #1a1a1a)}body.dark-mode .models-header{border-bottom-color:var(--border-dark)}body.dark-mode .models-header h1{color:var(--text-dark)}body.dark-mode .models-tabs{border-bottom-color:var(--border-dark);background:var(--bg-primary-dark)}body.dark-mode .models-tab{color:var(--text-secondary-dark)}body.dark-mode .models-tab:hover{color:var(--text-dark)}body.dark-mode .models-controls{border-bottom-color:var(--border-dark)}body.dark-mode .search-input,body.dark-mode .filter-select{background:var(--bg-secondary-dark);border-color:var(--border-dark);color:var(--text-dark)}body.dark-mode .search-input::placeholder{color:var(--text-secondary-dark)}body.dark-mode .models-empty h2,body.dark-mode .models-error .error-title{color:var(--text-dark)}body.dark-mode .models-empty p,body.dark-mode .models-error .error-message{color:var(--text-secondary-dark)}body.dark-mode .public-model-card{background:var(--bg-secondary-dark);border-color:var(--border-dark)}body.dark-mode .public-model-card:hover{box-shadow:0 4px 12px #0000004d}body.dark-mode .public-model-title{color:var(--text-dark)}body.dark-mode .public-model-description,body.dark-mode .public-model-stat,body.dark-mode .public-model-date{color:var(--text-secondary-dark)}body.dark-mode .public-model-stats{border-top-color:var(--border-dark)}@media (max-width: 768px){.models-view,.models-view.sidebar-collapsed{left:0;width:100vw}.models-header{padding:16px}.models-header h1{font-size:1.5rem}.models-tabs{padding:0 16px}.models-tab{padding:12px 16px;font-size:.9rem}.models-controls{flex-direction:column;align-items:stretch;padding:12px 16px}.search-container{max-width:none}.filter-container{justify-content:flex-end}.models-content{padding:16px}.models-grid,.models-grid.two-column{grid-template-columns:1fr;gap:12px}}.models-view-container{position:fixed;top:0;left:280px;right:0;bottom:0;display:flex;height:100vh;width:calc(100vw - 280px);background:var(--bg-primary, #ffffff);transition:left .3s ease,width .3s ease}.models-view-container.sidebar-collapsed{left:60px;width:calc(100vw - 60px)}.models-panel-center{flex:1;display:flex;flex-direction:column;min-width:0;overflow:hidden}.models-panel-right{min-width:30%;max-width:70%;display:flex;flex-direction:column;border-left:1px solid var(--border);background:var(--bg-primary, #ffffff)}@media (max-width: 768px){.models-view-container{left:0;width:100vw}.models-panel-right{display:none}}body.dark-mode .models-view-container,body.dark-mode .models-panel-right{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-dark)}.create-model-modal{position:fixed;top:0;left:0;right:0;bottom:0;display:flex;align-items:center;justify-content:center;z-index:1000;padding:20px}.create-model-modal .modal-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.create-model-modal .modal-content{position:relative;background:var(--bg-primary, #ffffff);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;z-index:1}body.dark-mode .create-model-modal .modal-content{background:var(--bg-primary-dark, #1a1a1a);box-shadow:0 20px 60px #000000b3}.model-card{background:var(--bg-secondary, #f9fafb);border:1px solid var(--border, #e5e7eb);border-radius:12px;padding:24px;cursor:pointer;transition:all .2s ease;display:flex;flex-direction:column;gap:16px;min-height:320px}.model-card:hover{border-color:var(--primary, #3b82f6);box-shadow:0 8px 24px #0000001f;transform:translateY(-4px)}body.dark-mode .model-card{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-dark, #444)}body.dark-mode .model-card:hover{box-shadow:0 8px 24px #0006}.model-card-header{display:flex;align-items:flex-start;justify-content:space-between;gap:12px}.model-card-title-section{display:flex;align-items:flex-start;gap:12px;flex:1;min-width:0}.model-card-title{margin:0;font-size:1.25rem;font-weight:600;color:var(--text, #111827);line-height:1.4;flex:1}body.dark-mode .model-card-title{color:var(--text-dark, #f9fafb)}.model-card-badge{padding:6px 12px;background:#8b5cf61a;color:#7c3aed;border-radius:6px;font-size:.75rem;font-weight:600;white-space:nowrap;flex-shrink:0}body.dark-mode .model-card-badge{background:#8b5cf633;color:#a78bfa}.model-card-creator{font-size:.85rem;color:var(--text-secondary, #6b7280);font-style:italic;margin-top:-8px}body.dark-mode .model-card-creator{color:var(--text-secondary-dark, #9ca3af)}.model-card-delete-btn{background:transparent;border:none;font-size:1.3rem;cursor:pointer;padding:6px 10px;border-radius:6px;transition:all .2s ease;flex-shrink:0;opacity:.7}.model-card-delete-btn:hover{background:#ef44441a;opacity:1;transform:scale(1.1)}.model-card-delete-btn:active{transform:scale(.95)}.model-card-description{margin:0;color:var(--text-secondary, #6b7280);font-size:.95rem;line-height:1.5;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;min-height:48px}body.dark-mode .model-card-description{color:var(--text-secondary-dark, #9ca3af)}.model-card-performance{display:flex;flex-direction:row;gap:16px;padding:16px;background:var(--bg-primary, #ffffff);border:1px solid var(--border, #e5e7eb);border-radius:8px;align-items:center}body.dark-mode .model-card-performance{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-dark, #444)}.performance-chart-container{flex:1;height:80px;position:relative;min-width:0}.sparkline-chart{width:100%;height:100%}.sparkline-path{stroke:var(--text, #111827)}.sparkline-path.positive{stroke:#059669}.sparkline-path.negative{stroke:#dc2626}.sparkline-path.neutral{stroke:#6b7280}body.dark-mode .sparkline-path.positive{stroke:#10b981}body.dark-mode .sparkline-path.negative{stroke:#ef4444}body.dark-mode .sparkline-path.neutral{stroke:#9ca3af}.gradient-start.positive,.gradient-end.positive{stop-color:#059669}.gradient-start.negative,.gradient-end.negative{stop-color:#dc2626}.gradient-start.neutral,.gradient-end.neutral{stop-color:#6b7280}body.dark-mode .gradient-start.positive,body.dark-mode .gradient-end.positive{stop-color:#10b981}body.dark-mode .gradient-start.negative,body.dark-mode .gradient-end.negative{stop-color:#ef4444}body.dark-mode .gradient-start.neutral,body.dark-mode .gradient-end.neutral{stop-color:#9ca3af}.performance-metrics-column{display:flex;flex-direction:column;justify-content:center;gap:8px;min-width:120px}.performance-metric{display:flex;flex-direction:column;align-items:flex-start;gap:2px}.metric-label-small{font-size:.7rem;color:var(--text-secondary, #6b7280);font-weight:500;text-transform:uppercase;letter-spacing:.05em}body.dark-mode .metric-label-small{color:var(--text-secondary-dark, #9ca3af)}.metric-value-large{font-size:1.25rem;font-weight:700}.metric-value-small{font-size:.9rem;font-weight:600}.metric-value-large.positive,.metric-value-small.positive{color:#059669}.metric-value-large.negative,.metric-value-small.negative{color:#dc2626}.metric-value-large.neutral,.metric-value-small.neutral{color:var(--text, #111827)}body.dark-mode .metric-value-large.positive,body.dark-mode .metric-value-small.positive{color:#10b981}body.dark-mode .metric-value-large.negative,body.dark-mode .metric-value-small.negative{color:#ef4444}body.dark-mode .metric-value-large.neutral,body.dark-mode .metric-value-small.neutral{color:var(--text-dark, #f9fafb)}.model-card-performance-placeholder{display:flex;align-items:center;justify-content:center;padding:32px 16px;background:var(--bg-primary, #ffffff);border:1px dashed var(--border, #e5e7eb);border-radius:8px}body.dark-mode .model-card-performance-placeholder{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-dark, #444)}.placeholder-text{font-size:.85rem;color:var(--text-secondary, #9ca3af);font-style:italic}body.dark-mode .placeholder-text{color:var(--text-secondary-dark, #6b7280)}.model-card-stats{display:flex;align-items:center;gap:20px;padding-top:12px;border-top:1px solid var(--border, #e5e7eb)}body.dark-mode .model-card-stats{border-top-color:var(--border-dark, #444)}.stat-item{display:flex;align-items:center;gap:6px;color:var(--text-secondary, #6b7280);font-size:.85rem}body.dark-mode .stat-item{color:var(--text-secondary-dark, #9ca3af)}.stat-item svg{opacity:.7;flex-shrink:0}.model-card-stat-value{font-weight:500;color:inherit;font-size:inherit}.model-card-footer{display:flex;align-items:center;justify-content:space-between;margin-top:auto;gap:12px}.footer-date{color:var(--text-secondary, #9ca3af);font-size:.8rem}.model-card-footer-actions{display:flex;gap:8px;align-items:center}.model-card-share-btn{display:flex;align-items:center;gap:6px;padding:6px 12px;background:var(--bg-primary, #ffffff);border:1px solid var(--border, #e5e7eb);border-radius:6px;color:var(--text-secondary, #6b7280);font-size:.8rem;font-weight:500;cursor:pointer;transition:all .2s ease}.model-card-share-btn:hover{background:var(--bg-secondary, #f3f4f6);border-color:var(--primary, #3b82f6);color:var(--primary, #3b82f6)}.model-card-share-btn svg{flex-shrink:0}body.dark-mode .model-card-share-btn{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-dark, #444);color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .model-card-share-btn:hover{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--primary-light, #60a5fa);color:var(--primary-light, #60a5fa)}body.dark-mode .footer-date{color:var(--text-secondary-dark, #6b7280)}@media (max-width: 768px){.model-card{padding:20px;min-height:280px}.model-card-title{font-size:1.1rem}.model-card-description{font-size:.9rem}.performance-chart-container{height:60px}.performance-metrics-column{gap:6px;min-width:100px}.metric-value-large{font-size:1.1rem}.metric-value-small{font-size:.85rem}.model-card-stats{gap:16px;flex-wrap:wrap}.stat-item{font-size:.8rem}}@media (max-width: 480px){.model-card{padding:16px;gap:12px}.model-card-header{flex-direction:column;align-items:flex-start}.model-card-performance{flex-direction:column;gap:12px}.performance-chart-container{width:100%;height:50px}.performance-metrics-column{width:100%;gap:6px}.metric-label-small{font-size:.65rem}.metric-value-large{font-size:1rem}}.model-card-stats .stat-item.activity-indicator{color:var(--primary, #3b82f6);font-weight:600}.model-card-stats .stat-item.activity-indicator svg{stroke:var(--primary, #3b82f6)}body.dark-mode .model-card-stats .stat-item.activity-indicator{color:var(--primary-light, #60a5fa)}body.dark-mode .model-card-stats .stat-item.activity-indicator svg{stroke:var(--primary-light, #60a5fa)}.model-card-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px}.model-card-modal{background:var(--bg-primary, #ffffff);border-radius:12px;box-shadow:0 20px 25px -5px #0000001a,0 10px 10px -5px #0000000a;max-width:500px;width:100%;max-height:90vh;overflow-y:auto}body.dark-mode .model-card-modal{background:var(--bg-primary-dark, #1a1a1a);box-shadow:0 20px 25px -5px #0000004d,0 10px 10px -5px #0003}.model-card-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border, #e5e7eb)}body.dark-mode .model-card-modal-header{border-bottom-color:var(--border-dark, #444)}.model-card-modal-header h3{margin:0;font-size:1.25rem;font-weight:600;color:var(--text, #111827)}body.dark-mode .model-card-modal-header h3{color:var(--text-dark, #f9fafb)}.model-card-modal-close{background:transparent;border:none;font-size:1.5rem;cursor:pointer;padding:4px;color:var(--text-secondary, #6b7280);border-radius:6px;transition:all .2s ease}.model-card-modal-close:hover{background:var(--bg-secondary, #f3f4f6);color:var(--text, #111827)}body.dark-mode .model-card-modal-close{color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .model-card-modal-close:hover{background:var(--bg-secondary-dark, #2a2a2a);color:var(--text-dark, #f9fafb)}.model-card-modal-body{padding:24px}.model-card-modal-body p{margin:0 0 16px;color:var(--text, #374151);line-height:1.6}body.dark-mode .model-card-modal-body p{color:var(--text-dark, #d1d5db)}.model-card-modal-warning{padding:12px 16px;background:#ef44441a;border-left:4px solid #dc2626;border-radius:6px;font-size:.9rem;color:#991b1b;margin:16px 0 0!important}body.dark-mode .model-card-modal-warning{background:#ef444433;border-left-color:#ef4444;color:#fca5a5}.model-card-modal-actions{display:flex;gap:12px;padding:20px 24px;border-top:1px solid var(--border, #e5e7eb);justify-content:flex-end}body.dark-mode .model-card-modal-actions{border-top-color:var(--border-dark, #444)}.model-card-modal-cancel,.model-card-modal-confirm{padding:10px 20px;border-radius:8px;font-weight:600;font-size:.9rem;cursor:pointer;transition:all .2s ease;border:none}.model-card-modal-cancel{background:var(--bg-secondary, #f3f4f6);color:var(--text, #374151)}.model-card-modal-cancel:hover{background:var(--border, #e5e7eb)}body.dark-mode .model-card-modal-cancel{background:var(--bg-secondary-dark, #2a2a2a);color:var(--text-dark, #d1d5db)}body.dark-mode .model-card-modal-cancel:hover{background:var(--border-dark, #555)}.model-card-modal-confirm{background:#dc2626;color:#fff}.model-card-modal-confirm:hover{background:#b91c1c}.model-card-modal-confirm:disabled,.model-card-modal-cancel:disabled{opacity:.5;cursor:not-allowed}.news-card{background:var(--bg-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-sm);border:1px solid var(--border-primary);overflow:hidden;cursor:pointer;transition:box-shadow .2s ease;display:flex;flex-direction:column;height:375px}.news-card:hover{box-shadow:var(--shadow-md)}.news-card-image-container{width:100%;flex-shrink:0;background:var(--bg-secondary);overflow:hidden;height:45%;position:relative}.news-card-image{width:100%;height:100%;object-fit:cover}.news-card-image-container:after{content:"";position:absolute;bottom:0;left:0;right:0;height:40%;background:linear-gradient(to bottom,transparent 0%,var(--bg-primary) 100%);pointer-events:none}body.dark-mode .news-card-image-container:after{background:linear-gradient(to bottom,transparent 0%,var(--bg-primary) 100%)}.news-card-content{padding:12px;flex:1;display:flex;flex-direction:column;overflow:hidden}.news-card-meta{display:flex;align-items:center;justify-content:space-between;margin-bottom:8px}.news-card-meta-left{display:flex;align-items:center;gap:8px}.news-card-impact-badge{padding:4px 8px;font-size:var(--font-xs);font-weight:600;border-radius:var(--radius-sm);border:1px solid}.news-card-impact-badge.high{background:#fef2f2;color:#991b1b;border-color:#fecaca}.news-card-impact-badge.medium{background:#fefce8;color:#854d0e;border-color:#fde047}.news-card-impact-badge.low{background:#f0fdf4;color:#166534;border-color:#bbf7d0}.news-card-time,.news-card-views{font-size:var(--font-xs);color:var(--text-tertiary)}.news-card-headline{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);margin-bottom:8px;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.4}.news-card-summary{font-size:var(--font-xs);color:var(--text-secondary);margin-bottom:8px;flex:1;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;line-height:1.5}.news-card-footer{display:flex;flex-direction:column;gap:4px;margin-top:auto}.news-card-tickers{display:flex;flex-wrap:wrap;gap:4px}.news-card-ticker{padding:2px 8px;font-size:var(--font-xs);font-family:monospace;background:#eff6ff;color:#1e40af;border-radius:var(--radius-sm);border:1px solid #bfdbfe;cursor:pointer;transition:all .2s ease}.news-card-ticker:hover{background:#dbeafe;border-color:#93c5fd}.news-card-ticker-more{padding:2px 8px;font-size:var(--font-xs);color:var(--text-tertiary)}.news-card-sources-container{position:relative}.news-card-sources-btn{display:flex;align-items:center;gap:4px;padding:4px 8px;font-size:var(--font-xs);color:var(--text-secondary);background:var(--bg-secondary);border-radius:var(--radius-sm);border:1px solid var(--border-primary);cursor:pointer;transition:all .2s ease}.news-card-sources-btn:hover{color:var(--text-primary);border-color:var(--border-secondary, #ced4da)}.news-card-sources-icon{width:12px;height:12px}.news-card-sources-dropdown{position:absolute;bottom:100%;left:0;margin-bottom:8px;width:288px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);box-shadow:var(--shadow-lg);z-index:10;max-height:256px;overflow-y:auto}.news-card-sources-dropdown-content{padding:12px}.news-card-sources-title{font-size:var(--font-xs);font-weight:600;color:var(--text-secondary);margin-bottom:8px}.news-card-sources-list{display:flex;flex-direction:column;gap:8px}.news-card-source-link{display:block;font-size:var(--font-xs);color:var(--info-vibrant);text-decoration:none;transition:all .2s ease}.news-card-source-link:hover{color:var(--info-hover, #2563eb);text-decoration:underline}body.dark-mode .news-card{background:var(--bg-primary);border-color:var(--border-primary)}body.dark-mode .news-card-impact-badge.high{background:#7f1d1d;color:#fca5a5;border-color:#991b1b}body.dark-mode .news-card-impact-badge.medium{background:#78350f;color:#fcd34d;border-color:#854d0e}body.dark-mode .news-card-impact-badge.low{background:#14532d;color:#86efac;border-color:#166534}body.dark-mode .news-card-ticker{background:#1e3a8a;color:#93c5fd;border-color:#1e40af}body.dark-mode .news-card-ticker:hover{background:#1e40af;border-color:#3b82f6}.discover-view-container{position:fixed;left:280px;top:0;width:calc(100vw - 280px);height:100vh;display:flex;background:var(--bg-primary, #ffffff);transition:left .3s ease,width .3s ease}.discover-view-container.sidebar-collapsed{left:60px;width:calc(100vw - 60px)}.discover-panel-center{flex:1;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.discover-panel-center::-webkit-scrollbar{display:none}.discover-panel-right{height:100vh;border-left:1px solid #e5e7eb;overflow:hidden;flex-shrink:0;background:#fff}.discover-content{flex:1;padding:2rem 1rem}.news-grid{display:flex;flex-wrap:wrap;gap:20px;width:100%}.discover-view-container .news-card{flex:1 1 auto;width:auto;max-width:none}.discover-filters{display:flex;align-items:center;gap:24px;padding:20px 24px;background:var(--bg-secondary, #f8f9fa);border-radius:12px;margin-bottom:24px;flex-wrap:wrap}.filter-group{display:flex;align-items:center;gap:12px}.filter-label{font-size:14px;font-weight:600;color:var(--text-secondary, #666666);white-space:nowrap}.filter-buttons{display:flex;gap:8px;flex-wrap:wrap}.filter-btn{padding:8px 14px;border-radius:8px;border:1px solid var(--border-color, #dee2e6);background:var(--background-primary, #ffffff);color:var(--text-primary, #333333);font-size:14px;font-weight:500;cursor:pointer;transition:all .2s ease;white-space:nowrap}.filter-btn:hover{border-color:var(--primary-color, #007bff);background:var(--bg-hover, rgba(0, 0, 0, .02))}.filter-btn.active{background:var(--primary-color, #007bff);color:#fff;border-color:var(--primary-color, #007bff)}.filter-btn.active.high-impact{background:#ef4444;border-color:#ef4444}.filter-btn.active.medium-impact{background:#f59e0b;border-color:#f59e0b}.filter-btn.active.low-impact{background:#10b981;border-color:#10b981}.ticker-search-input{padding:10px 16px;border:1px solid var(--border-color, #dee2e6);border-radius:10px;background:var(--background-primary, #ffffff);color:var(--text-primary, #333333);font-size:14px;font-weight:500;min-width:180px;transition:border-color .2s}.ticker-search-input:focus{outline:none;border-color:var(--primary-color, #007bff);box-shadow:0 0 0 3px #3b82f61a}.ticker-search-input::placeholder{color:var(--text-tertiary, #999)}.refresh-btn{margin-left:auto;padding:10px 20px;border:none;border-radius:10px;background:var(--primary-color, #007bff);color:#fff;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;white-space:nowrap}.refresh-btn:hover:not(:disabled){background:var(--accent-hover, #0056b3);transform:translateY(-1px);box-shadow:0 4px 12px #007aff4d}.refresh-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.discover-view-container,.discover-view-container.sidebar-collapsed{left:0;width:100vw}.discover-panel-right{position:fixed;top:0;left:0;width:100vw;z-index:1000}.discover-filters{flex-direction:column;gap:16px;align-items:stretch}.filter-group{flex-direction:column;align-items:stretch}.ticker-search-input{width:100%;min-width:auto}.refresh-btn{margin-left:0;width:100%}}.conversation-search-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#0009;z-index:9998;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px)}.conversation-search-modal{position:fixed;top:50%;left:50%;transform:translate(-50%,-50%);width:90%;max-width:600px;max-height:80vh;background:var(--bg-primary);border-radius:12px;box-shadow:0 8px 32px #0000004d;z-index:9999;display:flex;flex-direction:column;overflow:hidden}.conversation-search-modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid var(--border-primary)}.conversation-search-modal-header h2{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.conversation-search-modal-close{padding:8px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s ease;display:flex;align-items:center;justify-content:center}.conversation-search-modal-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.conversation-search-modal-input-container{position:relative;padding:20px 24px;border-bottom:1px solid var(--border-primary)}.conversation-search-modal-input-container .search-icon{position:absolute;left:36px;top:50%;transform:translateY(-50%);color:var(--text-tertiary);pointer-events:none}.conversation-search-modal-input{width:100%;padding:12px 16px 12px 44px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;font-size:15px;color:var(--text-primary);transition:all .2s ease}.conversation-search-modal-input::placeholder{color:var(--text-tertiary)}.conversation-search-modal-input:focus{outline:none;border-color:var(--brand-primary);background:var(--bg-primary)}.search-loading-spinner{position:absolute;right:36px;top:50%;transform:translateY(-50%)}.spinner{width:20px;height:20px;border:2px solid var(--border-primary);border-top-color:var(--brand-primary);border-radius:50%;animation:spin .6s linear infinite}.conversation-search-modal-results{flex:1;overflow-y:auto;padding:8px;min-height:200px;max-height:calc(80vh - 200px)}.conversation-search-modal-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;color:var(--text-tertiary)}.conversation-search-modal-empty svg{margin-bottom:16px;opacity:.5}.conversation-search-modal-empty p{font-size:16px;font-weight:500;color:var(--text-secondary);margin:0 0 8px}.conversation-search-modal-empty span{font-size:14px;color:var(--text-tertiary)}.conversation-search-modal-results-list{display:flex;flex-direction:column;gap:2px}.conversation-search-result-item{padding:12px 16px;border-radius:8px;cursor:pointer;transition:all .2s ease;background:transparent}.conversation-search-result-item:hover{background:var(--bg-secondary)}.conversation-search-result-item.active{background:var(--bg-secondary);border-left:3px solid var(--brand-primary);padding-left:13px}.conversation-search-result-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:4px}.conversation-search-result-title{font-size:14px;font-weight:600;color:var(--text-primary);flex:1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-right:12px}.conversation-search-result-date{font-size:12px;color:var(--text-tertiary);white-space:nowrap}.conversation-search-result-snippet{font-size:13px;color:var(--text-secondary);line-height:1.5;margin-top:6px;padding:8px 10px;background:var(--bg-tertiary);border-radius:6px;border-left:2px solid var(--brand-primary)}.match-type-badge{display:inline-block;padding:2px 8px;background:var(--brand-primary);color:#fff;border-radius:4px;font-size:10px;font-weight:600;text-transform:uppercase;letter-spacing:.5px;margin-right:8px;margin-bottom:4px}.conversation-search-result-match-type{margin-top:6px}.dark-mode .conversation-search-modal-overlay{background:#000c}.dark-mode .conversation-search-modal{background:#1a1a1a;box-shadow:0 8px 32px #0009}.dark-mode .conversation-search-modal-header,.dark-mode .conversation-search-modal-input-container{border-color:#2a2a2a}.dark-mode .conversation-search-modal-input{background:#2d2d2d;border-color:#2a2a2a}.dark-mode .conversation-search-modal-input:focus{background:#1a1a1a}.dark-mode .conversation-search-result-item:hover,.dark-mode .conversation-search-result-item.active{background:#2d2d2d}.dark-mode .conversation-search-result-snippet{background:#121212}.dark-mode .conversation-search-modal-close:hover{background:#2d2d2d}@media (max-width: 768px){.conversation-search-modal{width:95%;max-width:none;max-height:90vh}.conversation-search-modal-header{padding:16px 20px}.conversation-search-modal-header h2{font-size:18px}.conversation-search-modal-input-container{padding:16px 20px}.conversation-search-modal-results{padding:4px}.conversation-search-result-item{padding:10px 12px}}.group-search-result{display:flex;flex-direction:row;align-items:flex-start;gap:12px}.group-search-result-avatar{position:relative;flex-shrink:0;width:48px;height:48px;margin-top:2px}.group-search-result-avatar img{width:100%;height:100%;border-radius:50%;object-fit:cover}.group-avatar-fallback{width:100%;height:100%;border-radius:50%;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-secondary) 100%);display:flex;align-items:center;justify-content:center;font-weight:600;font-size:16px;color:#fff;text-transform:uppercase}.group-unread-badge{position:absolute;top:-4px;right:-4px;min-width:20px;height:20px;padding:0 6px;background:#ff3b30;color:#fff;border-radius:10px;font-size:11px;font-weight:600;display:flex;align-items:center;justify-content:center;border:2px solid var(--bg-primary);box-shadow:0 2px 8px #ff3b3066}.group-search-result-content{flex:1;min-width:0}.group-search-result .conversation-search-result-header{margin-bottom:4px}.group-search-result .conversation-search-result-title{font-weight:600;font-size:15px}.group-search-result .conversation-search-result-date{font-size:12px;opacity:.7}.group-search-result .conversation-search-result-snippet{margin-top:6px;font-size:13px}.group-search-result:hover .group-avatar-fallback{transform:scale(1.05);transition:transform .2s ease}.group-search-result:hover .group-unread-badge{transform:scale(1.1);transition:transform .2s ease}.username-modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000c;display:flex;align-items:center;justify-content:center;z-index:10000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.username-modal{background-color:var(--bg-secondary, #1a1a1a);border-radius:16px;padding:40px;max-width:420px;width:90%;text-align:center;box-shadow:0 20px 60px #00000080}.username-modal-error{background-color:#ef44441a;border:1px solid rgba(239,68,68,.3);color:#ef4444;padding:12px 16px;border-radius:8px;margin-bottom:24px;font-size:14px}.username-modal-icon{color:var(--text-secondary, #888);margin-bottom:24px}.username-modal-icon svg{opacity:.6}.username-modal-title{font-size:28px;font-weight:700;color:var(--text-primary, #fff);margin:0 0 12px}.username-modal-subtitle{font-size:15px;color:var(--text-secondary, #888);margin:0 0 32px;line-height:1.5}.username-input-container{display:flex;align-items:center;background-color:var(--bg-tertiary, #2a2a2a);border:2px solid var(--border-color, #333);border-radius:12px;padding:0 16px;height:56px;transition:border-color .2s ease}.username-input-container:focus-within{border-color:var(--accent-color, #3b82f6)}.username-input-prefix{font-size:18px;color:var(--text-secondary, #888);font-weight:500;margin-right:2px}.username-input{flex:1;background:none;border:none;outline:none;font-size:18px;color:var(--text-primary, #fff);font-weight:500}.username-input::placeholder{color:var(--text-tertiary, #555)}.username-input:disabled{opacity:.6}.username-validation-icon{width:24px;height:24px;display:flex;align-items:center;justify-content:center;margin-left:8px}.username-spinner{width:20px;height:20px;border:2px solid var(--border-color, #333);border-top-color:var(--accent-color, #3b82f6);border-radius:50%;animation:username-spin .8s linear infinite}@keyframes username-spin{to{transform:rotate(360deg)}}.username-icon-success{color:#22c55e}.username-icon-error{color:#ef4444}.username-validation-message{font-size:13px;margin:12px 0 0;text-align:left;padding-left:4px}.username-validation-message.available{color:#22c55e}.username-validation-message.taken,.username-validation-message.invalid{color:#ef4444}.username-validation-message.idle,.username-validation-message.checking{color:var(--text-secondary, #888)}.username-helper-text{font-size:12px;color:var(--text-tertiary, #666);margin:8px 0 24px;text-align:left;padding-left:4px}.username-submit-button{width:100%;height:52px;border:none;border-radius:12px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.username-submit-button.enabled{background-color:var(--accent-color, #3b82f6);color:#fff}.username-submit-button.enabled:hover{background-color:var(--accent-color-hover, #2563eb);transform:translateY(-1px)}.username-submit-button.enabled:active{transform:translateY(0)}.username-submit-button.disabled{background-color:var(--bg-tertiary, #2a2a2a);color:var(--text-tertiary, #666);cursor:not-allowed}:root[data-theme=light] .username-modal{background-color:#fff;box-shadow:0 20px 60px #0003}:root[data-theme=light] .username-modal-overlay{background-color:#00000080}:root{--bg-primary: #ffffff;--bg-secondary: #f8f9fa;--bg-tertiary: #f0f0f0;--text-primary: #333333;--text-secondary: #666666;--text-tertiary: #495057;--border-primary: #dee2e6;--border-secondary: #ddd;--accent-primary: #007bff;--accent-hover: #0056b3;--success-bg: #d4edda;--success-text: #155724;--danger-bg: #f8d7da;--danger-text: #721c24;--warning-bg: #fff3cd;--warning-text: #856404;--info-bg: #d1ecf1;--info-text: #0c5460;--shadow: rgba(0, 0, 0, .1);--success-vibrant: #10b981;--danger-vibrant: #ef4444;--warning-vibrant: #f59e0b;--info-vibrant: #3b82f6;--gradient-primary: linear-gradient(135deg, #667eea 0%, #764ba2 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-info: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .1);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .1);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .1);--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .25s cubic-bezier(.4, 0, .2, 1);--transition-slow: .35s cubic-bezier(.4, 0, .2, 1);--background-primary: #ffffff;--background-secondary: #f8f9fa;--border-color: #dee2e6;--primary-color: #007bff;--hover-background: #f0f0f0;--success-color: #28a745;--error-color: #dc3545;--bg-hover: rgba(0, 0, 0, .02);--danger-color: #dc3545;--danger-hover: #c82333;--positive-color: #10b981;--negative-color: #ef4444;--brand-primary: #6b7280;--brand-primary-dark: #4b5563;--font-xs: .75rem;--font-sm: .875rem;--font-base: 1rem;--font-lg: 1.125rem;--font-xl: 1.25rem;--font-2xl: 1.5rem;--font-3xl: 1.875rem;--font-4xl: 2.25rem;--space-1: .25rem;--space-2: .5rem;--space-3: .75rem;--space-4: 1rem;--space-5: 1.25rem;--space-6: 1.5rem;--space-8: 2rem;--space-10: 2.5rem;--space-12: 3rem;--space-16: 4rem;--radius-sm: 4px;--radius-base: 6px;--radius-md: 8px;--radius-lg: 12px;--radius-xl: 16px;--radius-full: 9999px;--z-base: 0;--z-dropdown: 10;--z-sticky: 50;--z-overlay: 100;--z-modal: 200;--z-popover: 300;--z-tooltip: 400;--z-notification: 500}body.dark-mode{--bg-primary: #1a1a1a;--bg-secondary: #2d2d2d;--bg-tertiary: #121212;--text-primary: #e0e0e0;--text-secondary: #b0b0b0;--text-tertiary: #a0a0a0;--border-primary: #404040;--border-secondary: #505050;--accent-primary: #4dabff;--accent-hover: #3d8fd9;--success-bg: #1e4e2a;--success-text: #7fd99a;--danger-bg: #4e1e1e;--danger-text: #ff9999;--warning-bg: rgba(245, 158, 11, .15);--warning-text: #f59e0b;--info-bg: rgba(59, 130, 246, .15);--info-text: #3b82f6;--shadow: rgba(0, 0, 0, .5);--background-primary: #1a1a1a;--background-secondary: #2d2d2d;--border-color: #404040;--border-color-dark: #404040;--text-primary-dark: #e0e0e0;--text-secondary-dark: #b0b0b0;--primary-color: #4dabff;--hover-background: #333333;--success-color: #10b981;--error-color: #ef4444;--bg-hover: rgba(255, 255, 255, .05);--danger-color: #dc3545;--danger-hover: #c82333;--positive-color: #10b981;--negative-color: #ef4444;--brand-primary: #9ca3af;--brand-primary-dark: #6b7280;--success-vibrant: #10b981;--danger-vibrant: #ef4444;--warning-vibrant: #f59e0b;--info-vibrant: #3b82f6;--gradient-primary: linear-gradient(135deg, #6366f1 0%, #8b5cf6 100%);--gradient-success: linear-gradient(135deg, #10b981 0%, #059669 100%);--gradient-danger: linear-gradient(135deg, #ef4444 0%, #dc2626 100%);--gradient-info: linear-gradient(135deg, #3b82f6 0%, #2563eb 100%);--shadow-sm: 0 1px 2px 0 rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px -1px rgba(0, 0, 0, .4);--shadow-lg: 0 10px 15px -3px rgba(0, 0, 0, .5);--shadow-xl: 0 20px 25px -5px rgba(0, 0, 0, .6)}html{overscroll-behavior:none;height:100%;width:100%;font-size:16px;background-color:var(--bg-primary)}body{background-color:var(--bg-primary);color:var(--text-primary);transition:background-color .3s ease,color .3s ease;margin:0;padding:0;height:100%;width:100%;overflow:hidden;overscroll-behavior:none;position:relative;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Open Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}#root{width:100%;height:100%;background-color:var(--bg-primary)}h1,h2,h3,h4,h5,h6{margin:0;font-weight:600;line-height:1.2;color:var(--text-primary)}h1{font-size:var(--font-4xl)}h2{font-size:var(--font-3xl)}h3{font-size:var(--font-2xl)}h4{font-size:var(--font-xl)}h5{font-size:var(--font-lg)}h6{font-size:var(--font-base)}p{margin:0;line-height:1.6}a{color:var(--accent-primary);text-decoration:none;transition:color var(--transition-fast)}a:hover{color:var(--accent-hover)}button{font-family:inherit;font-size:inherit;cursor:pointer;background:transparent;border:none;padding:0;color:inherit}button:disabled{opacity:.5;cursor:not-allowed}input,textarea,select{font-family:inherit;font-size:inherit;color:inherit;background:transparent;border:none;outline:none}table{border-collapse:collapse;width:100%}ul,ol{list-style:none;margin:0;padding:0}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:var(--accent-primary);color:#fff}::-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(--border-secondary)}.hide-scrollbar{scrollbar-width:none;-ms-overflow-style:none}.hide-scrollbar::-webkit-scrollbar{display:none}.smooth-scroll{scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.sr-only{position:absolute;width:1px;height:1px;padding:0;margin:-1px;overflow:hidden;clip:rect(0,0,0,0);white-space:nowrap;border:0}@media (prefers-reduced-motion: reduce){*,*:before,*:after{animation-duration:.01ms!important;animation-iteration-count:1!important;transition-duration:.01ms!important}}@media (prefers-contrast: high){:root{--border-primary: #000;--border-secondary: #333}body.dark-mode{--border-primary: #fff;--border-secondary: #ccc}}.hidden{display:none!important}.block{display:block}.inline-block{display:inline-block}.inline{display:inline}.flex{display:flex}.inline-flex{display:inline-flex}.grid{display:grid}.flex-row{flex-direction:row}.flex-col{flex-direction:column}.flex-wrap{flex-wrap:wrap}.flex-nowrap{flex-wrap:nowrap}.items-start{align-items:flex-start}.items-center{align-items:center}.items-end{align-items:flex-end}.items-stretch{align-items:stretch}.justify-start{justify-content:flex-start}.justify-center{justify-content:center}.justify-end{justify-content:flex-end}.justify-between{justify-content:space-between}.justify-around{justify-content:space-around}.flex-1{flex:1}.flex-auto{flex:auto}.flex-none{flex:none}.gap-1{gap:var(--space-1)}.gap-2{gap:var(--space-2)}.gap-3{gap:var(--space-3)}.gap-4{gap:var(--space-4)}.gap-5{gap:var(--space-5)}.gap-6{gap:var(--space-6)}.gap-8{gap:var(--space-8)}.grid-cols-1{grid-template-columns:repeat(1,1fr)}.grid-cols-2{grid-template-columns:repeat(2,1fr)}.grid-cols-3{grid-template-columns:repeat(3,1fr)}.grid-cols-4{grid-template-columns:repeat(4,1fr)}.grid-cols-auto{grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.p-0{padding:0}.p-1{padding:var(--space-1)}.p-2{padding:var(--space-2)}.p-3{padding:var(--space-3)}.p-4{padding:var(--space-4)}.p-5{padding:var(--space-5)}.p-6{padding:var(--space-6)}.p-8{padding:var(--space-8)}.px-0{padding-left:0;padding-right:0}.px-1{padding-left:var(--space-1);padding-right:var(--space-1)}.px-2{padding-left:var(--space-2);padding-right:var(--space-2)}.px-3{padding-left:var(--space-3);padding-right:var(--space-3)}.px-4{padding-left:var(--space-4);padding-right:var(--space-4)}.px-5{padding-left:var(--space-5);padding-right:var(--space-5)}.px-6{padding-left:var(--space-6);padding-right:var(--space-6)}.px-8{padding-left:var(--space-8);padding-right:var(--space-8)}.py-0{padding-top:0;padding-bottom:0}.py-1{padding-top:var(--space-1);padding-bottom:var(--space-1)}.py-2{padding-top:var(--space-2);padding-bottom:var(--space-2)}.py-3{padding-top:var(--space-3);padding-bottom:var(--space-3)}.py-4{padding-top:var(--space-4);padding-bottom:var(--space-4)}.py-5{padding-top:var(--space-5);padding-bottom:var(--space-5)}.py-6{padding-top:var(--space-6);padding-bottom:var(--space-6)}.py-8{padding-top:var(--space-8);padding-bottom:var(--space-8)}.m-0{margin:0}.m-1{margin:var(--space-1)}.m-2{margin:var(--space-2)}.m-3{margin:var(--space-3)}.m-4{margin:var(--space-4)}.m-5{margin:var(--space-5)}.m-6{margin:var(--space-6)}.m-8{margin:var(--space-8)}.m-auto{margin:auto}.mx-auto{margin-left:auto;margin-right:auto}.my-auto{margin-top:auto;margin-bottom:auto}.mt-0{margin-top:0}.mt-1{margin-top:var(--space-1)}.mt-2{margin-top:var(--space-2)}.mt-3{margin-top:var(--space-3)}.mt-4{margin-top:var(--space-4)}.mt-5{margin-top:var(--space-5)}.mt-6{margin-top:var(--space-6)}.mt-8{margin-top:var(--space-8)}.mb-0{margin-bottom:0}.mb-1{margin-bottom:var(--space-1)}.mb-2{margin-bottom:var(--space-2)}.mb-3{margin-bottom:var(--space-3)}.mb-4{margin-bottom:var(--space-4)}.mb-5{margin-bottom:var(--space-5)}.mb-6{margin-bottom:var(--space-6)}.mb-8{margin-bottom:var(--space-8)}.text-xs{font-size:var(--font-xs)}.text-sm{font-size:var(--font-sm)}.text-base{font-size:var(--font-base)}.text-lg{font-size:var(--font-lg)}.text-xl{font-size:var(--font-xl)}.text-2xl{font-size:var(--font-2xl)}.text-3xl{font-size:var(--font-3xl)}.text-4xl{font-size:var(--font-4xl)}.font-normal{font-weight:400}.font-medium{font-weight:500}.font-semibold{font-weight:600}.font-bold{font-weight:700}.text-left{text-align:left}.text-center{text-align:center}.text-right{text-align:right}.uppercase{text-transform:uppercase}.lowercase{text-transform:lowercase}.capitalize{text-transform:capitalize}.normal-case{text-transform:none}.tracking-tight{letter-spacing:-.05em}.tracking-normal{letter-spacing:0}.tracking-wide{letter-spacing:.05em}.leading-none{line-height:1}.leading-tight{line-height:1.25}.leading-normal{line-height:1.5}.leading-relaxed{line-height:1.625}.leading-loose{line-height:2}.truncate{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.line-clamp-1{display:-webkit-box;-webkit-line-clamp:1;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-2{display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.line-clamp-3{display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden}.text-primary{color:var(--text-primary)}.text-secondary{color:var(--text-secondary)}.text-tertiary{color:var(--text-tertiary)}.text-accent{color:var(--accent-primary)}.text-success{color:var(--success-vibrant)}.text-danger{color:var(--danger-vibrant)}.text-warning{color:var(--warning-vibrant)}.text-info{color:var(--info-vibrant)}.text-white{color:#fff}.text-black{color:#000}.bg-primary{background-color:var(--bg-primary)}.bg-secondary{background-color:var(--bg-secondary)}.bg-tertiary{background-color:var(--bg-tertiary)}.bg-accent{background-color:var(--accent-primary)}.bg-success{background-color:var(--success-bg)}.bg-danger{background-color:var(--danger-bg)}.bg-transparent{background-color:transparent}.border-0{border:0}.border{border:1px solid var(--border-primary)}.border-2{border:2px solid var(--border-primary)}.border-t{border-top:1px solid var(--border-primary)}.border-r{border-right:1px solid var(--border-primary)}.border-b{border-bottom:1px solid var(--border-primary)}.border-l{border-left:1px solid var(--border-primary)}.border-primary{border-color:var(--border-primary)}.border-secondary{border-color:var(--border-secondary)}.border-accent{border-color:var(--accent-primary)}.border-success{border-color:var(--success-vibrant)}.border-danger{border-color:var(--danger-vibrant)}.rounded-none{border-radius:0}.rounded-sm{border-radius:var(--radius-sm)}.rounded{border-radius:var(--radius-base)}.rounded-md{border-radius:var(--radius-md)}.rounded-lg{border-radius:var(--radius-lg)}.rounded-xl{border-radius:var(--radius-xl)}.rounded-full{border-radius:var(--radius-full)}.shadow-none{box-shadow:none}.shadow-sm{box-shadow:var(--shadow-sm)}.shadow{box-shadow:var(--shadow-md)}.shadow-lg{box-shadow:var(--shadow-lg)}.shadow-xl{box-shadow:var(--shadow-xl)}.static{position:static}.relative{position:relative}.absolute{position:absolute}.fixed{position:fixed}.sticky{position:sticky}.top-0{top:0}.right-0{right:0}.bottom-0{bottom:0}.left-0{left:0}.inset-0{top:0;right:0;bottom:0;left:0}.overflow-auto{overflow:auto}.overflow-hidden{overflow:hidden}.overflow-visible{overflow:visible}.overflow-scroll{overflow:scroll}.overflow-x-auto{overflow-x:auto;overflow-y:visible}.overflow-y-auto{overflow-x:visible;overflow-y:auto}.overflow-x-hidden{overflow-x:hidden}.overflow-y-hidden{overflow-y:hidden}.w-full{width:100%}.w-auto{width:auto}.w-screen{width:100vw}.w-min{width:min-content}.w-max{width:max-content}.w-fit{width:fit-content}.h-full{height:100%}.h-auto{height:auto}.h-screen{height:100vh}.h-min{height:min-content}.h-max{height:max-content}.h-fit{height:fit-content}.max-w-xs{max-width:20rem}.max-w-sm{max-width:24rem}.max-w-md{max-width:28rem}.max-w-lg{max-width:32rem}.max-w-xl{max-width:36rem}.max-w-2xl{max-width:42rem}.max-w-3xl{max-width:48rem}.max-w-4xl{max-width:56rem}.max-w-5xl{max-width:64rem}.max-w-6xl{max-width:72rem}.max-w-full{max-width:100%}.max-w-none{max-width:none}.z-0{z-index:var(--z-base)}.z-10{z-index:var(--z-dropdown)}.z-50{z-index:var(--z-sticky)}.z-100{z-index:var(--z-overlay)}.z-200{z-index:var(--z-modal)}.z-300{z-index:var(--z-popover)}.z-400{z-index:var(--z-tooltip)}.z-500{z-index:var(--z-notification)}.cursor-auto{cursor:auto}.cursor-default{cursor:default}.cursor-pointer{cursor:pointer}.cursor-wait{cursor:wait}.cursor-move{cursor:move}.cursor-not-allowed{cursor:not-allowed}.transition-none{transition:none}.transition-all{transition:all var(--transition-base)}.transition-fast{transition:all var(--transition-fast)}.transition-slow{transition:all var(--transition-slow)}.transition-colors{transition:background-color var(--transition-base),border-color var(--transition-base),color var(--transition-base)}.transition-opacity{transition:opacity var(--transition-base)}.transition-transform{transition:transform var(--transition-base)}.scale-90{transform:scale(.9)}.scale-95{transform:scale(.95)}.scale-100{transform:scale(1)}.scale-105{transform:scale(1.05)}.scale-110{transform:scale(1.1)}.rotate-0{transform:rotate(0)}.rotate-45{transform:rotate(45deg)}.rotate-90{transform:rotate(90deg)}.rotate-180{transform:rotate(180deg)}.translate-x-0{transform:translate(0)}.translate-y-0{transform:translateY(0)}.-translate-x-full{transform:translate(-100%)}.translate-x-full{transform:translate(100%)}.-translate-y-full{transform:translateY(-100%)}.translate-y-full{transform:translateY(100%)}.opacity-0{opacity:0}.opacity-25{opacity:.25}.opacity-50{opacity:.5}.opacity-75{opacity:.75}.opacity-100{opacity:1}.pointer-events-none{pointer-events:none}.pointer-events-auto{pointer-events:auto}.select-none{-webkit-user-select:none;user-select:none}.select-text{-webkit-user-select:text;user-select:text}.select-all{-webkit-user-select:all;user-select:all}.select-auto{-webkit-user-select:auto;user-select:auto}@media (min-width: 769px){.desktop-only{display:block}.mobile-only{display:none!important}.app{max-width:1200px;margin:0 auto;padding:0;height:100vh;display:flex;flex-direction:column}.header{display:none!important}.header-left{flex:0 0 auto}.header-center{flex:1 1 auto;display:flex;justify-content:center;max-width:600px;margin:0 auto}.header-right{flex:0 0 auto}.nav-tabs{display:flex;gap:4px}.nav-tab{background:transparent;border:none;padding:6px 12px;font-size:14px;font-weight:500;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s ease}.nav-tab:hover,.nav-tab.active{background:var(--bg-secondary);color:var(--text-primary)}.nav-icon{display:none}.nav-label{display:inline}.search-container{position:relative;width:100%;max-width:400px}.search-icon{position:absolute;left:12px;top:50%;transform:translateY(-50%);color:var(--text-secondary);pointer-events:none}.search-input{width:100%;padding:8px 32px 8px 36px;border:none;border-radius:8px;font-size:14px;background:var(--bg-secondary);color:var(--text-primary);transition:all .2s ease}.search-input::placeholder{color:var(--text-secondary);font-size:12px;letter-spacing:.4px;font-weight:500}.search-input:focus{outline:none;background:var(--bg-tertiary);box-shadow:0 0 0 4px #007bff1a}body.dark-mode .search-input{background:#ffffff1a}body.dark-mode .search-input:focus{background:#ffffff26;box-shadow:0 0 0 4px #4dabff1a}.theme-toggle{background:transparent;border:none;border-radius:8px;padding:8px;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;color:var(--text-secondary)}.theme-toggle:hover{background:var(--bg-secondary);color:var(--text-primary)}.ticker-list,.company-container,.markets-container{flex:1;overflow-y:auto;background:var(--bg-primary);border-radius:8px;box-shadow:0 2px 4px var(--shadow)}.chat-container{flex:1;overflow-y:auto;background:var(--bg-tertiary);border-radius:0;box-shadow:none}.ticker-table{width:100%;border-collapse:collapse;font-size:12px}.ticker-table th{background:var(--bg-secondary);padding:8px 10px;text-align:left;font-weight:600;color:var(--text-tertiary);border-bottom:2px solid var(--border-primary);white-space:nowrap;transition:all .3s ease;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.ticker-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.ticker-table th.sortable:hover{background:var(--bg-tertiary)}.ticker-table td{padding:6px 10px;border-bottom:1px solid var(--border-primary);transition:border-color .3s ease}.ticker-table tr:hover{background:var(--bg-secondary)}.pagination{padding:20px;background:var(--bg-secondary);border-top:1px solid var(--border-primary);display:flex;flex-direction:column;gap:15px;transition:background-color .3s ease}.pagination-info{text-align:center;color:var(--text-secondary);font-size:14px}.pagination-controls{display:flex;justify-content:center;align-items:center;gap:8px;flex-wrap:wrap}.pagination-btn{padding:6px 12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:4px;color:var(--text-tertiary);font-size:14px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.movers-grid{display:grid;grid-template-columns:1fr 1fr;gap:20px}.markets-grid{display:grid;grid-template-columns:1fr 1fr;gap:16px}.financial-statements-grid{display:grid;grid-template-columns:1fr 1fr;gap:30px;margin-bottom:30px}.chart-controls{display:flex;gap:20px;align-items:center;flex-wrap:wrap}.chart-timeframes{display:flex;gap:4px;background:var(--bg-secondary);padding:4px;border-radius:6px}.timeframe-btn{background:transparent;border:none;color:var(--text-secondary);padding:6px 12px;font-size:12px;font-weight:500;cursor:pointer;border-radius:4px;transition:all .2s}.timeframe-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.timeframe-btn.active{background:var(--bg-primary);color:var(--accent-primary);font-weight:600}.chat-messages{flex:1;overflow-y:auto;padding:20px;background:var(--bg-tertiary)}.chat-input-container{flex-shrink:0;padding:20px 20px 10px;background:var(--bg-tertiary);border-top:1px solid var(--border-primary)}.chat-input-wrapper{display:flex;align-items:flex-end;gap:12px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;padding:8px;transition:all .2s ease}.chat-input-wrapper.with-nav-pill{display:grid!important;grid-template-columns:1fr!important;grid-template-rows:auto 1fr!important;gap:8px!important;padding:12px 16px 10px!important;align-items:start!important;min-height:90px!important}.chat-input-wrapper.with-nav-pill .chat-input{grid-column:1;grid-row:1;align-self:stretch;padding-bottom:0}.chat-input-wrapper.with-nav-pill .chat-send-btn{grid-column:1;grid-row:2;align-self:end;justify-self:end;margin-left:0;margin-right:8px;margin-bottom:2px}.chat-input-wrapper.with-nav-pill .nav-pill-inline{grid-column:1;grid-row:2;align-self:end;justify-content:flex-start;margin-bottom:2px}.chat-input-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #007bff1a}.market-section{background:var(--bg-primary);border-radius:12px;padding:16px;box-shadow:var(--shadow-sm);transition:all var(--transition-base);border:1px solid var(--border-primary)}.market-section:hover{box-shadow:var(--shadow-lg);transform:translateY(-2px)}.company-card{background:var(--bg-primary);border-radius:8px;padding:20px;box-shadow:0 2px 4px var(--shadow)}.market-news-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:24px}@media (min-width: 1200px){.market-news-grid{grid-template-columns:repeat(3,1fr)}}@media (min-width: 1600px){.market-news-grid{grid-template-columns:repeat(4,1fr)}}.expanded-row td{padding:0!important;background:var(--bg-secondary);border-bottom:2px solid var(--border-primary)}.inline-details-panel{animation:expandDown .3s ease-out;overflow:hidden}@keyframes expandDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.company-header-extended{margin-bottom:24px;background:var(--bg-primary);border-radius:8px;box-shadow:0 2px 4px var(--shadow);overflow:hidden}.company-header{padding:24px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid var(--border-secondary)}.company-stats{display:flex;gap:24px}.index-chart-container{display:flex;gap:30px;align-items:flex-start}.index-chart-container .chart-area{flex:1;min-width:0}.index-chart-stats{display:flex;flex-direction:column;gap:12px;padding-left:20px;min-width:180px}}@media (max-width: 768px){.mobile-only{display:block}.desktop-only{display:none!important}body{font-size:16px;overflow-x:hidden}h1{font-size:28px}h2{font-size:24px}h3{font-size:20px}h4{font-size:18px}.app{display:flex;flex-direction:column;height:100vh;position:fixed;top:0;left:0;right:0;bottom:0;padding:0;padding-top:env(safe-area-inset-top,0);padding-bottom:env(safe-area-inset-bottom,0);overflow:hidden}.app.has-mobile-search{padding-top:56px}.mobile-top-bar{display:flex!important;position:fixed;top:0;left:0;right:0;height:56px;background:#f9f9f9f0;border-bottom:.5px solid rgba(0,0,0,.1);backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);z-index:999;align-items:center;justify-content:center;padding:0 12px}body.dark-mode .mobile-top-bar{background:#1d1d1ff0;border-bottom:.5px solid rgba(255,255,255,.15)}.mobile-hamburger{position:absolute;left:8px;width:32px;height:32px;border-radius:6px;border:1px solid rgba(0,0,0,.1);background:transparent;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;cursor:pointer;transition:all .2s ease;flex-shrink:0}.mobile-hamburger:active{background:#7676801f;transform:scale(.95)}body.dark-mode .mobile-hamburger{border-color:#ffffff1a}body.dark-mode .mobile-hamburger:active{background:#76768033}.mobile-search-container{flex:1;max-width:100%;position:relative;display:flex;align-items:center;margin-left:40px}.mobile-search-input{width:100%;padding:10px 12px;background:#7676801f;border:none;border-radius:10px;font-size:17px;color:var(--text-primary);-webkit-appearance:none;-moz-appearance:none;appearance:none}.mobile-search-input::placeholder{color:#3c3c4399;font-size:17px}body.dark-mode .mobile-search-input{background:#6363664d;color:#fff}body.dark-mode .mobile-search-input::placeholder{color:#ebebf54d}.header{position:fixed;bottom:0;left:0;right:0;top:auto;z-index:1000;background:#f9f9f9f0;border-top:.5px solid rgba(0,0,0,.1);border-bottom:none;margin-bottom:0;padding:0;padding-bottom:env(safe-area-inset-bottom,0);height:calc(83px + env(safe-area-inset-bottom,0));display:flex;align-items:flex-start;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%)}body.dark-mode .header{background:#1d1d1ff0;border-top:.5px solid rgba(255,255,255,.15)}.header-left{flex:1;width:100%;height:83px}.header-center,.header-right{display:none}.nav-tabs{display:flex;gap:0;justify-content:space-around;align-items:center;width:100%;height:83px;padding:0 8px}.nav-tab{flex:1;font-size:11px;padding:8px 4px;min-width:0;max-width:80px;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:4px;border-radius:0;border:none;position:relative;background:transparent;color:#999;transition:all .2s ease;height:100%;min-height:48px}.nav-tab:active{transform:scale(.92);opacity:.6}.nav-tab.active{color:#007aff;background:transparent}body.dark-mode .nav-tab{color:#8e8e93}body.dark-mode .nav-tab.active{color:#0a84ff}.nav-tab.company-tab{display:none!important}.mobile-theme-tab{display:flex!important}.nav-icon{display:flex;align-items:center;justify-content:center;width:30px;height:30px}.nav-icon svg{width:28px;height:28px;stroke-width:2}.nav-tab.active .nav-icon svg{stroke-width:2.5}.nav-label{display:block;font-size:10px;margin-top:2px}.ticker-list,.markets-container,.company-container{height:calc(100vh - 83px - env(safe-area-inset-top,0) - env(safe-area-inset-bottom,0));overflow-y:auto;-webkit-overflow-scrolling:touch;padding:12px}.markets-container{padding-top:12px}.company-container{padding-top:10px}.mobile-chat-input-bar{position:fixed;bottom:env(safe-area-inset-bottom,0);left:0;right:0;background:var(--bg-primary);border-top:1px solid var(--border-primary);padding:12px;z-index:998}.mobile-chat-input-bar.centered{position:absolute!important;top:33%!important;left:50%!important;transform:translate(-50%,-50%)!important;bottom:auto!important;width:90%!important;background:transparent!important;border-top:none!important;padding:0!important;z-index:10!important}.mobile-chat-input-bar .chat-input-wrapper{display:flex;align-items:center;gap:8px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:24px;padding:8px 12px}.mobile-chat-input-bar .chat-input-wrapper.with-nav-pill{display:grid!important;grid-template-columns:1fr!important;grid-template-rows:auto 1fr!important;gap:6px!important;padding:8px 12px!important;align-items:start!important;min-height:80px!important}.mobile-chat-input-bar .chat-input-wrapper.with-nav-pill .chat-input{grid-column:1!important;grid-row:1!important;align-self:stretch!important;padding-bottom:0!important}.mobile-chat-input-bar .chat-input-wrapper.with-nav-pill .chat-send-btn{grid-column:1!important;grid-row:2!important;align-self:end!important;justify-self:end!important;margin-left:0!important;margin-right:6px!important;margin-bottom:2px!important}.mobile-chat-input-bar .nav-pill-inline{grid-column:1!important;grid-row:2!important;padding-top:0!important;margin-top:0!important;margin-bottom:2px!important;position:relative;display:flex!important;align-items:flex-end!important;justify-content:flex-start!important}.mobile-chat-input-bar .nav-pill-inline .nav-pill-button{display:inline-flex;align-items:center;gap:6px;padding:3px 10px;background:linear-gradient(135deg,#6b7280,#4b5563);border:1px solid #6b7280;border-radius:12px;cursor:pointer;font-size:11px;font-weight:600;color:#fff;box-shadow:0 1px 3px #6b72801a}.mobile-chat-input-bar .chat-input{flex:1;background:transparent;border:none;outline:none;font-size:16px;line-height:1.5;color:var(--text-primary);resize:none;min-height:24px;max-height:100px}.mobile-chat-input-bar .chat-send-btn{width:44px;height:44px;border-radius:50%;background:transparent;border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;color:var(--accent-primary);transition:all .2s ease;padding:0}.mobile-chat-input-bar .chat-send-btn svg{width:28px;height:28px}.table-container{width:100%;overflow-x:hidden}.ticker-table{width:100%;table-layout:fixed}.ticker-table th,.ticker-table td{padding:16px 8px;font-size:16px;text-align:left}.ticker-table th{background:transparent;border-bottom:1px solid var(--border-secondary);font-weight:500;font-size:16px;color:var(--text-secondary);padding:10px 8px;text-transform:capitalize;letter-spacing:0}.ticker-table th:nth-child(1),.ticker-table td:nth-child(1){width:20%}.ticker-table th:nth-child(2),.ticker-table td:nth-child(2){width:50%}.ticker-table th:nth-child(3),.ticker-table td:nth-child(3){width:30%;text-align:right}.ticker-table .ticker-symbol{font-weight:600;font-size:16px}.ticker-table .name-column{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.ticker-table .market-cap{text-align:right;font-weight:500}.market-section{padding:16px;border-radius:12px}.market-section h3{font-size:18px;margin-bottom:16px}.status-badge{font-size:16px;padding:10px 16px}.next-holiday{font-size:14px;padding:6px 12px}.mover-ticker,.mover-price,.mover-change,.sector-name,.sector-change,.crypto-name,.crypto-price,.crypto-change{font-size:17px!important}.forex-pair{font-size:15px!important}.forex-rate{font-size:19px!important}.forex-change{font-size:16px!important}.indices-grid{grid-template-columns:1fr 1fr;gap:12px}.movers-grid,.markets-grid,.forex-grid{grid-template-columns:1fr}.market-news-grid{grid-template-columns:1fr;gap:16px}.sector-row,.crypto-row,.dividend-row,.split-row{padding:14px;min-height:48px}.ipo-card{padding:14px}.chart-timeframes{gap:2px;padding:2px;width:100%;justify-content:space-between}.timeframe-btn{padding:6px 4px;font-size:11px;flex:1;min-width:0}.chart-placeholder{height:300px}.company-header{flex-direction:column;gap:20px;align-items:flex-start}.company-stats{width:100%;justify-content:space-between}.stat-item{align-items:flex-start}.news-item{flex-direction:column}.news-image-thumb{width:100px;height:70px}}@media (max-width: 480px){.indices-grid{grid-template-columns:1fr}.status-badge{font-size:16px;padding:10px 16px}.next-holiday{font-size:14px;padding:6px 12px}.index-card-horizontal .index-name{font-size:15px}.index-card-horizontal .index-price{font-size:16px}}@supports (padding: max(0px)){.mobile-top-bar{padding-top:env(safe-area-inset-top,0);height:calc(56px + env(safe-area-inset-top,0))}.app.has-mobile-search{padding-top:calc(56px + env(safe-area-inset-top,0))}.header{padding-bottom:env(safe-area-inset-bottom,0);height:calc(83px + env(safe-area-inset-bottom,0))}}.ticker-table{width:100%;border-collapse:collapse;font-size:12px}.ticker-table th{background:var(--bg-secondary);padding:8px 10px;text-align:left;font-weight:600;color:var(--text-tertiary);border-bottom:2px solid var(--border-primary);white-space:nowrap;transition:all .3s ease;font-size:11px;text-transform:uppercase;letter-spacing:.5px}.ticker-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none}.ticker-table th.sortable:hover{background:var(--bg-tertiary)}.ticker-table td{padding:6px 10px;border-bottom:1px solid var(--border-primary);transition:border-color .3s ease}.ticker-table tr:hover{background:var(--bg-secondary)}.ticker-symbol{font-weight:600;color:var(--accent-primary)}.ticker-cell{display:flex;align-items:center;gap:10px}.company-logo{width:20px;height:20px;object-fit:contain;border-radius:3px;background:var(--bg-primary);padding:1px;border:1px solid var(--border-primary)}.logo-placeholder{width:20px;height:20px;border-radius:3px;background:var(--bg-secondary);border:1px solid var(--border-primary);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:10px;color:var(--text-tertiary)}.clickable-row{cursor:pointer;transition:background-color .2s}.clickable-row:hover{background-color:var(--bg-secondary)}.row-selected{background-color:var(--bg-secondary)!important}.expanded-row td{padding:0!important;background:var(--bg-secondary);border-bottom:2px solid var(--border-primary)}.inline-details-panel{animation:expandDown .3s ease-out;overflow:hidden}.inline-details-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.inline-details-title{display:flex;align-items:baseline;gap:12px}.details-ticker{font-size:20px;font-weight:700;color:var(--accent-primary)}.details-name{font-size:16px;color:var(--text-secondary)}.inline-details-body{padding:20px;max-height:none;overflow:visible;background:var(--bg-primary)}.details-section h4{margin:0 0 10px;color:var(--text-tertiary);font-size:14px;text-transform:uppercase;letter-spacing:.5px}.details-section p{margin:0;line-height:1.6;color:var(--text-primary);font-size:14px;word-wrap:break-word;overflow-wrap:break-word;white-space:normal}.detail-label{font-size:12px;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.detail-value{font-size:14px;color:var(--text-primary);font-weight:500;word-wrap:break-word;overflow-wrap:break-word}.details-actions{display:flex;gap:8px;align-items:center}.view-company-btn{background:var(--accent-primary);color:#fff;border:none;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:500;cursor:pointer;transition:all .2s}.view-company-btn:hover{background:var(--accent-hover);transform:translate(2px)}.close-details{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:0;width:30px;height:30px;display:flex;align-items:center;justify-content:center;border-radius:4px;transition:all .2s}.close-details:hover{background:var(--bg-tertiary);color:var(--text-primary)}.price,.change{text-align:right;font-weight:500}.change.positive{color:#16a34a}.change.negative{color:#dc2626}body.dark-mode .change.positive{color:#4ade80}body.dark-mode .change.negative{color:#f87171}.change-percent{text-align:right;font-weight:500}.change-percent.positive{color:#16a34a}.change-percent.negative{color:#dc2626}body.dark-mode .change-percent.positive{color:#4ade80}body.dark-mode .change-percent.negative{color:#f87171}.market-cap{font-weight:500;text-align:right}.employees{text-align:right}.sic-desc{max-width:200px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap;color:var(--text-primary)}.status{padding:4px 8px;border-radius:4px;font-size:12px;font-weight:500}.status.active{background:var(--success-bg);color:var(--success-text)}.status.inactive{background:var(--danger-bg);color:var(--danger-text)}.movers-table{width:100%;border-collapse:collapse;font-size:12px}.movers-table th{background:var(--bg-tertiary);padding:8px 12px;text-align:left;font-weight:600;color:var(--text-tertiary);border-bottom:1px solid var(--border-primary);font-size:11px;text-transform:uppercase;letter-spacing:.5px}.movers-table td{padding:6px 12px;border-bottom:1px solid var(--border-primary);transition:background-color .2s ease}.movers-table tr:hover td{background:var(--bg-secondary)}.movers-table .ticker-symbol{font-weight:600;color:var(--accent-primary)}.movers-table .price{text-align:right;font-weight:500}.movers-table .volume{text-align:right;color:var(--text-secondary)}.action-item{display:flex;align-items:flex-start;gap:8px;padding:10px 12px;margin:8px 0;background:var(--bg-secondary);border-left:3px solid var(--primary);border-radius:4px;font-size:14px;line-height:1.5;animation:fadeInLeft .3s ease-out}@keyframes fadeInLeft{0%{opacity:0;transform:translate(-10px)}to{opacity:1;transform:translate(0)}}.action-item-icon{font-size:16px;margin-top:2px;flex-shrink:0}.action-item-text{flex:1;color:var(--text-primary)}body.dark-mode .action-item{background:#4a90e21a;border-left-color:#4a90e2}.chat-container{display:flex;flex-direction:column;height:100vh;background:var(--bg-primary);overflow:hidden;padding-bottom:0}@media (max-width: 768px){.chat-container{padding-bottom:75px}}.chat-messages{flex:1;overflow-y:auto;padding:20px 40px;background:var(--bg-primary);scroll-behavior:smooth;-webkit-overflow-scrolling:touch;margin-top:0;scrollbar-width:none}@media (max-width: 768px){.chat-messages{margin-top:0}}body.dark-mode .chat-messages{background:var(--bg-primary)}.chat-message{display:flex;flex-direction:column;margin-bottom:20px;animation:fadeInUp .3s ease-out}@keyframes fadeInUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.chat-message.user{align-items:flex-end}.chat-message.assistant{align-items:flex-start}.message-content{display:flex;flex-direction:column;gap:6px}.chat-message.assistant .message-content{max-width:100%;width:100%}.chat-message.user .message-content{max-width:90%}.message-content.has-chart{width:100%}.chat-message.user .message-content.has-chart{width:90%}.message-role{font-size:11px;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;font-weight:600;padding:0 12px;margin-bottom:6px;display:flex;align-items:center;gap:6px}.chat-message.user .message-role{justify-content:flex-end}.chat-message.assistant .message-role{justify-content:flex-start}.system-badge{display:inline-flex;align-items:center;justify-content:center;width:16px;height:16px;background-color:var(--primary-color);color:#fff;border-radius:50%;opacity:.8;cursor:help}.system-badge svg{width:10px;height:10px}.chat-message.system-generated.user .message-text{border-left:2px solid var(--primary-color);padding-left:14px}.message-text{color:var(--text-primary);font-size:15px;line-height:1.5;white-space:pre-wrap;word-wrap:break-word;display:block;text-align:left}.chat-message.assistant .message-text{width:100%}.chat-message.user .message-text{display:inline-block}.chat-message.user .message-text{padding:12px 16px;border-radius:12px;background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.chat-message.assistant .message-text{padding:0;background:transparent;box-shadow:none}.chat-message.assistant .message-content.has-component{background:transparent;border-radius:0;padding:0;box-shadow:none;overflow:visible}.chat-message.assistant .message-content.has-component .message-text{border-radius:0;box-shadow:none;margin:0;background:transparent}body.dark-mode .chat-message.assistant .message-text{background:transparent}body.dark-mode .chat-message.user .message-text{background:var(--bg-secondary);color:var(--text-primary);border-color:var(--border-primary)}.message-text h1,.message-text h2,.message-text h3,.message-text h4,.message-text h5,.message-text h6{margin-top:16px;margin-bottom:8px;font-weight:600;line-height:1.3}.message-text h1{font-size:1.8em}.message-text h2{font-size:1.5em}.message-text h3{font-size:1.3em}.message-text h4{font-size:1.1em}.message-text h5{font-size:1em}.message-text h6{font-size:.9em}.message-text p{margin:8px 0;line-height:1.6}.message-text ul,.message-text ol{margin:12px 0;padding-left:24px}.message-text li{margin:4px 0;line-height:1.6}.message-text blockquote{margin:12px 0;padding:8px 16px;border-left:4px solid var(--accent-primary);background:var(--bg-secondary);border-radius:4px}.chat-message.user .message-text blockquote{background:var(--bg-primary);border-left-color:var(--accent-primary)}.message-text code{background:var(--bg-secondary);color:var(--accent-primary);padding:2px 6px;border-radius:4px;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:.9em;border:1px solid var(--border-secondary)}.chat-message.user .message-text code{background:var(--bg-primary);color:var(--accent-primary);border-color:var(--border-secondary)}.message-text pre{background:var(--bg-secondary);border:1px solid var(--border-secondary);border-radius:8px;padding:12px;margin:12px 0;overflow-x:auto}.chat-message.user .message-text pre{background:var(--bg-primary);border-color:var(--border-secondary)}.message-text pre code{background:transparent;border:none;padding:0;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:.9em;line-height:1.5;color:var(--text-primary);display:block}.chat-message.user .message-text pre code{color:var(--text-primary)}.message-text table{width:100%;margin:12px 0;border-collapse:collapse;border:1px solid var(--border-secondary);border-radius:8px;overflow:hidden}.message-text th,.message-text td{padding:8px 12px;text-align:left;border-bottom:1px solid var(--border-secondary)}.message-text th{background:var(--bg-secondary);font-weight:600}.message-text tr:last-child td{border-bottom:none}.message-text tr:hover{background:var(--bg-secondary)}.chat-message.user .message-text table{border-color:var(--border-secondary)}.chat-message.user .message-text th{background:var(--bg-primary)}.chat-message.user .message-text td,.chat-message.user .message-text th{border-bottom-color:var(--border-secondary)}.message-text a{color:var(--accent-primary);text-decoration:none;border-bottom:1px solid transparent;transition:border-color .2s ease}.message-text a:hover{border-bottom-color:var(--accent-primary)}.chat-message.user .message-text a{color:var(--accent-primary);text-decoration:underline;text-decoration-color:var(--accent-primary)}.chat-message.user .message-text a:hover{text-decoration-color:var(--accent-hover)}.typing-indicator{display:flex;align-items:center;gap:4px;padding:12px 16px}.typing-indicator span{width:8px;height:8px;border-radius:50%;background:var(--text-secondary);animation:typing 1.4s infinite}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}.chat-input-container{flex-shrink:0;padding:20px 20px 10px;background:var(--bg-primary);border-top:none;width:80%;margin:0 auto;transition:transform .3s ease-in-out,margin .3s ease-in-out}.chat-input-container.centered{position:absolute;top:33%;left:50%;transform:translate(-50%,-50%);width:80%;max-width:700px;margin:0}.chat-input-wrapper{display:flex;align-items:flex-end;gap:12px;background:var(--bg-primary);border:1.5px solid #d0d5dd;border-radius:24px;padding:12px 16px;box-shadow:0 2px 8px #0000000f;transition:all .2s ease}.chat-input-wrapper.with-nav-pill{display:grid;grid-template-columns:1fr;grid-template-rows:auto 1fr;gap:8px;padding-bottom:10px;align-items:start;min-height:90px}.chat-input-wrapper.with-nav-pill .chat-input{grid-column:1;grid-row:1;align-self:stretch;padding-bottom:0}.chat-input-wrapper.with-nav-pill .chat-send-btn{grid-column:1;grid-row:2;align-self:end;justify-self:end;margin-left:0;margin-right:8px;margin-bottom:2px}.chat-input-wrapper:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #007bff1a}body.dark-mode .chat-input-wrapper{background:#2a2a2a;border-color:#505050;box-shadow:0 2px 8px #0000004d}.chat-input{flex:1;background:transparent;border:none;outline:none;font-size:16px;line-height:1.5;color:var(--text-primary);resize:none;min-height:32px;max-height:200px;padding:6px 8px;font-family:inherit}.chat-input::placeholder{color:var(--text-tertiary)}.chat-send-btn{width:48px;height:48px;border-radius:50%;background:transparent;color:var(--text-primary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0}.chat-send-btn svg{width:32px;height:32px}body.dark-mode .chat-send-btn{color:#fff}body:not(.dark-mode) .chat-send-btn{color:#000}.chat-send-btn:hover:not(:disabled){transform:scale(1.1);opacity:.8}.chat-send-btn:disabled{opacity:.5;cursor:not-allowed}.nav-pill-inline{grid-column:1;grid-row:2;padding-top:0;margin-top:0;margin-bottom:2px;position:relative;display:flex;align-items:flex-end;justify-content:flex-start}.nav-pill-inline .nav-pill-button{display:inline-flex;align-items:center;gap:6px;padding:4px 12px;background:linear-gradient(135deg,#6b7280,#4b5563);border:1px solid #6b7280;border-radius:14px;cursor:pointer;transition:all .2s ease;font-size:12px;font-weight:600;color:#fff;outline:none;box-shadow:0 1px 3px #6b72801a}.nav-pill-inline .nav-pill-button:hover{transform:translateY(-1px);box-shadow:0 2px 6px #6b728033;background:linear-gradient(135deg,#4b5563,#374151)}.nav-pill-inline .nav-pill-button:active{transform:translateY(0);box-shadow:0 1px 2px #6b728026}body.dark-mode .nav-pill-inline .nav-pill-button{background:linear-gradient(135deg,#52525b,#3f3f46);border-color:#52525b;box-shadow:0 1px 3px #52525b26}body.dark-mode .nav-pill-inline .nav-pill-button:hover{background:linear-gradient(135deg,#3f3f46,#27272a);box-shadow:0 2px 6px #52525b40}.chat-input-hint{font-size:11px;color:var(--text-tertiary);margin-top:8px;text-align:center}.message-text.error-message{background:#ef44441a;border:1px solid rgba(239,68,68,.3);color:var(--text-primary);white-space:pre-wrap}body.dark-mode .message-text.error-message{background:#ef444426;border:1px solid rgba(239,68,68,.4)}.portfolio-detail-placeholder{display:flex;align-items:center;gap:16px;padding:16px 20px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin:8px 0}.portfolio-detail-placeholder .portfolio-icon{font-size:32px;line-height:1}.portfolio-detail-placeholder h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.portfolio-detail-placeholder .placeholder-note{margin:0;font-size:14px;color:var(--text-secondary);font-style:italic}body.dark-mode .portfolio-detail-placeholder{background-color:var(--bg-secondary);border-color:var(--border-color)}.model-detail-placeholder{display:flex;align-items:center;gap:16px;padding:16px 20px;background-color:var(--bg-secondary);border:1px solid var(--border-color);border-radius:12px;margin:8px 0}.model-detail-placeholder .model-icon{font-size:32px;line-height:1}.model-detail-placeholder h4{margin:0 0 4px;font-size:16px;font-weight:600;color:var(--text-primary)}.model-detail-placeholder .placeholder-note{margin:0;font-size:14px;color:var(--text-secondary);font-style:italic}body.dark-mode .model-detail-placeholder{background-color:var(--bg-secondary);border-color:var(--border-color)}.token-metrics{padding:12px;background:var(--bg-secondary);border-radius:8px;margin-top:12px;font-size:12px;color:var(--text-secondary)}.token-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(100px,1fr));gap:8px}.token-metric{display:flex;flex-direction:column;gap:2px}.token-metric-label{font-size:10px;text-transform:uppercase;letter-spacing:.5px;color:var(--text-tertiary)}.token-metric-value{font-weight:600;color:var(--text-primary)}.token-metric-value.high{color:var(--danger-vibrant)}.token-metric-value.medium{color:var(--warning-vibrant)}.token-metric-value.low{color:var(--success-vibrant)}@media (max-width: 768px){.chat-messages{margin-bottom:150px}.chat-input-container{padding:12px}.chat-input-container.centered{position:absolute!important;top:33%!important;left:50%!important;transform:translate(-50%,-50%)!important;width:90%!important;max-width:100%!important;margin:0!important;padding:12px!important;bottom:auto!important}.chat-input-wrapper.with-nav-pill{display:grid!important;grid-template-columns:1fr!important;grid-template-rows:auto 1fr!important;gap:6px!important;min-height:80px!important}.chat-input-wrapper.with-nav-pill .chat-input{grid-column:1!important;grid-row:1!important;align-self:stretch!important;padding-bottom:0!important}.chat-input-wrapper.with-nav-pill .chat-send-btn{grid-column:1!important;grid-row:2!important;align-self:end!important;justify-self:end!important;margin-bottom:2px!important}.chat-input-wrapper.with-nav-pill .nav-pill-inline{grid-column:1!important;grid-row:2!important;align-self:end!important;margin-bottom:2px!important}}.transitional-timeline{display:flex;flex-direction:column;gap:8px;margin:16px 0;padding-left:8px}.timeline-step{display:flex;align-items:flex-start;position:relative;min-height:32px}.timeline-indicator{position:relative;width:24px;display:flex;flex-direction:column;align-items:center;flex-shrink:0}.timeline-dot{width:12px;height:12px;border-radius:50%;background:var(--text-tertiary);border:2px solid var(--bg-primary);z-index:2;position:relative;transition:all .3s ease}.timeline-dot.active{background:var(--primary-vibrant);border-color:var(--primary-vibrant);animation:pulse 1.5s ease-in-out infinite}.timeline-dot.complete{background:var(--success-vibrant);border-color:var(--success-vibrant)}.timeline-dot.pending{background:var(--text-tertiary);border-color:var(--bg-primary)}.timeline-dot.final{background:var(--primary-vibrant);border-color:var(--primary-vibrant);width:14px;height:14px}.timeline-line{position:absolute;top:16px;left:50%;transform:translate(-50%);width:2px;height:calc(100% + 8px);background:var(--border-primary);z-index:1}.timeline-content{flex:1;padding-left:12px;padding-top:0}.timeline-text{color:var(--text-secondary);font-size:14px;line-height:1.4;font-style:italic}.timeline-text.thinking-content{font-family:Courier New,monospace;background:var(--bg-secondary);padding:8px 12px;border-radius:4px;border-left:3px solid var(--primary-vibrant);white-space:pre-wrap;word-break:break-word}.timeline-step.active .timeline-text{color:var(--text-primary);font-style:normal}.timeline-step.complete .timeline-text{color:var(--text-tertiary);text-decoration:line-through;opacity:.7}.timeline-step.complete .timeline-text.thinking-content{text-decoration:none;opacity:.9}.timeline-final{display:flex;align-items:flex-start;position:relative;margin-top:16px}.timeline-final .timeline-content{padding-left:12px}.timeline-final .final-content{padding-top:4px}.timeline-final .final-content .message-text{margin:0}.pulse{display:inline-block;animation:fadePulse 1.5s infinite}@keyframes fadePulse{0%,to{opacity:.5}50%{opacity:1}}@keyframes pulse{0%{box-shadow:0 0 rgba(var(--primary-rgb),.4);transform:scale(1)}50%{box-shadow:0 0 0 8px rgba(var(--primary-rgb),0);transform:scale(1.1)}to{box-shadow:0 0 rgba(var(--primary-rgb),0);transform:scale(1)}}:root{--primary-rgb: 59, 130, 246;--success-rgb: 34, 197, 94}.message-model-table{margin:16px 0}.model-table-actions{display:flex;justify-content:flex-end;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color)}.save-model-btn{padding:8px 16px;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.model-saved-btn{display:flex;align-items:center;gap:8px;padding:8px 16px;background:var(--success-light, #e6f7e6);color:var(--success-color, #10b981);border:1px solid var(--success-color, #10b981);border-radius:6px;font-size:14px;font-weight:500;cursor:not-allowed;opacity:.8}.model-saved-btn svg{flex-shrink:0}.component-placeholder{display:flex;align-items:center;gap:16px;padding:16px 20px;margin:12px 0;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:12px;cursor:pointer;transition:all .2s ease;position:relative;overflow:hidden}.component-placeholder:before{content:"";position:absolute;left:0;top:0;bottom:0;width:4px;background:var(--brand-primary);transform:scaleY(0);transition:transform .2s ease}.component-placeholder:hover{border-color:var(--brand-primary);background:var(--bg-primary);transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.component-placeholder:hover:before{transform:scaleY(1)}.component-placeholder:active{transform:translateY(0)}.placeholder-icon{font-size:32px;flex-shrink:0;line-height:1}.placeholder-content{flex:1;min-width:0}.placeholder-content h4{margin:0 0 4px;font-size:15px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.placeholder-content p{margin:0;font-size:13px;color:var(--text-secondary)}.expand-icon{flex-shrink:0;color:var(--text-tertiary);transition:all .2s ease}.component-placeholder:hover .expand-icon{color:var(--brand-primary);transform:translate(2px,-2px)}body.dark-mode .component-placeholder{background:#1a1a1a;border-color:#2a2a2a}body.dark-mode .component-placeholder:hover{background:#0f0f0f;border-color:var(--brand-primary);box-shadow:0 4px 12px #0000004d}@media (max-width: 768px){.component-placeholder{padding:14px 16px;gap:12px}.placeholder-icon{font-size:28px}.placeholder-content h4{font-size:14px}.placeholder-content p{font-size:12px}.expand-icon{width:18px;height:18px}}.chat-stock-chart-container{margin:0;border-radius:0;overflow:hidden;background:transparent;box-shadow:none;animation:fadeIn .4s ease-in-out}.message-chart{margin:0;width:100%;max-width:100%;padding:16px;background:transparent}.message-chart.inline-chart{margin:0;padding:16px;width:100%;min-width:100%;background:transparent}.message-chart.inline-chart .chat-stock-chart-container{width:100%;min-width:100%}@media (max-width: 768px){.chat-stock-chart-container,.message-chart{margin-top:.75rem}}@media (prefers-color-scheme: dark){.chat-stock-chart-container{background:transparent;box-shadow:none}}.chat-data-table-container{margin:0;background:var(--bg-secondary);border-radius:0;border:0px solid var(--border-primary);overflow:hidden;box-shadow:none}.table-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;background:var(--bg-secondary);border-bottom:0px solid rgba(0,0,0,.08)}.table-title{margin:0;font-size:16px;font-weight:600;color:var(--color-text-primary)}.table-controls{display:flex;align-items:center;gap:12px}.table-search{padding:6px 12px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);color:var(--color-text-primary);font-size:14px;min-width:200px}.table-search:focus{outline:none;border-color:var(--color-primary)}.row-count{font-size:14px;color:var(--color-text-secondary)}.table-wrapper{overflow-x:auto;border-radius:8px;margin:0 16px;border:2px solid var(--border-primary)}.data-table{width:100%;border-collapse:separate;border-spacing:0;font-size:13px}body.dark-mode .data-table thead{background:#ffffff14}.data-table thead{background:#0000000f}.data-table th{padding:10px 12px;text-align:left;font-weight:700;color:var(--color-text-primary);border-bottom:2px solid var(--color-border);border-right:1px solid rgba(0,0,0,.05);-webkit-user-select:none;user-select:none}body.dark-mode .data-table th{background:#ffffff1f;border-right:1px solid rgba(255,255,255,.05);border-top:1px solid rgba(255,255,255,.05)}.data-table th{background:#0000000f;border-right:1px solid rgba(0,0,0,.05)}.data-table th:last-child{border-right:none}.data-table th.sortable{cursor:pointer;transition:background .2s}body.dark-mode .data-table th.sortable:hover{background:#ffffff1f}.data-table th.sortable:hover{background:#00000017}.header-content{display:flex;align-items:center;justify-content:space-between}.sort-indicator{margin-left:8px;color:var(--color-primary);font-weight:700}.data-table th.sorted-asc .sort-indicator,.data-table th.sorted-desc .sort-indicator{color:var(--color-primary)}.data-table td{padding:10px 12px;color:var(--color-text-primary);border-bottom:1px solid rgba(0,0,0,.04);border-right:1px solid rgba(0,0,0,.03)}body.dark-mode .data-table td{border-bottom:1px solid rgba(255,255,255,.04);border-right:1px solid rgba(255,255,255,.03)}.data-table td:last-child{border-right:none}.data-table{text-align:right;font-variant-numeric:tabular-nums}.data-table tbody tr{transition:background .2s}.data-table tbody tr.even-row{background:#00000003}.data-table tbody tr.odd-row{background:transparent}body.dark-mode .data-table tbody tr.even-row{background:#ffffff05}body.dark-mode .data-table tbody tr.odd-row{background:transparent}.data-table tbody tr:hover{background:#0000000a}body.dark-mode .data-table tbody tr:hover{background:#ffffff0d}.table-pagination{display:flex;justify-content:center;align-items:center;gap:8px;padding:12px 16px;background:transparent;border-top:1px solid rgba(0,0,0,.08)}.pagination-btn{padding:6px 12px;border:1px solid var(--color-border);border-radius:4px;background:var(--color-surface);color:var(--color-text-primary);font-size:14px;cursor:pointer;transition:all .2s}.pagination-btn:hover:not(:disabled){background:var(--color-primary);color:#fff;border-color:var(--color-primary)}.pagination-btn:disabled{opacity:.5;cursor:not-allowed}.pagination-info{padding:0 12px;font-size:14px;color:var(--color-text-secondary)}@media (max-width: 768px){.table-header{flex-direction:column;align-items:flex-start;gap:12px}.table-controls{width:100%;flex-direction:column;align-items:stretch}.table-search{width:100%}.data-table{font-size:12px}.data-table th,.data-table td{padding:8px}.table-pagination{flex-wrap:wrap}.pagination-btn{font-size:12px;padding:4px 8px}}.message-table{margin:0;padding:16px;background:transparent}.inline-table{animation:fadeIn .3s ease-in;background:transparent}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.movers-enhanced-list{display:flex;flex-direction:column;gap:8px}.mover-enhanced-row{display:flex;justify-content:space-between;align-items:stretch;padding:10px 12px;background:var(--background-primary);border:1px solid var(--border-color);border-radius:8px;cursor:pointer;transition:all .2s ease;min-height:70px}.mover-enhanced-row:hover{background:var(--background-tertiary);transform:translate(2px);box-shadow:0 2px 4px #0000000d}.mover-left-section{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.mover-percentage-display{font-size:20px;font-weight:700;padding:8px 12px;border-radius:6px;min-width:85px;text-align:center;display:flex;align-items:center;justify-content:center}.mover-percentage-display.positive{background:#10b9811a;color:var(--positive-color);border:1px solid rgba(16,185,129,.2)}.mover-percentage-display.negative{background:#ef44441a;color:var(--negative-color);border:1px solid rgba(239,68,68,.2)}.mover-company-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.mover-ticker{font-size:14px;font-weight:600;color:var(--text-primary)}.mover-name{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:180px}.mover-right-section{display:flex;align-items:center;gap:20px}.mover-data-group{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.mover-label{font-size:10px;font-weight:500;color:var(--text-tertiary);text-transform:uppercase;letter-spacing:.5px;opacity:.7}.mover-value{font-size:13px;font-weight:600;color:var(--text-primary);white-space:nowrap}.mover-value.rating{padding:2px 6px;background:var(--background-tertiary);border-radius:3px;font-size:11px;border:1px solid var(--border-color)}.mover-value.small{font-size:11px;font-weight:500;max-width:90px;overflow:hidden;text-overflow:ellipsis}.mover-details,.mover-price,.mover-change,.mover-market-cap{display:none}.earnings-calendar-section{margin-bottom:30px}.earnings-calendar-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:20px;margin-top:15px}.earnings-day-group{background:var(--background-secondary);border:1px solid var(--border-color);border-radius:8px;padding:15px;transition:all .2s ease}.earnings-day-group:hover{box-shadow:0 2px 8px #0000001a}.earnings-date-header{font-size:14px;font-weight:600;color:var(--text-primary);margin-bottom:12px;padding-bottom:8px;border-bottom:1px solid var(--border-color)}.earnings-companies{display:flex;flex-direction:column;gap:8px}.earnings-company-row{display:flex;justify-content:space-between;align-items:center;padding:8px 10px;background:var(--background-primary);border-radius:6px;cursor:pointer;transition:all .2s ease}.earnings-company-row:hover{background:var(--background-tertiary);transform:translate(2px)}.earnings-company-row.expanded{background:var(--background-tertiary);border-color:var(--accent-primary)}.earnings-company-info{display:flex;flex-direction:column;gap:2px;flex:1;min-width:0}.earnings-ticker{font-size:14px;font-weight:600;color:var(--text-primary)}.earnings-company-name{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.earnings-details{display:flex;flex-direction:column;align-items:flex-end;gap:4px}.earnings-timing{font-size:11px;padding:3px 8px;border-radius:4px;font-weight:500}.earnings-timing.bmo{background:#3b82f626;color:#3b82f6}.earnings-timing.amc{background:#a855f726;color:#a855f7}.earnings-timing.tas{background:#6b728026;color:var(--text-secondary)}.earnings-eps{font-size:11px;color:var(--text-secondary)}.earnings-expanded-content{background:var(--background-secondary);border:1px solid var(--border-color);border-top:none;margin:-1px 0 8px;border-radius:0 0 6px 6px;animation:expandDown .3s ease-out;overflow:hidden}.earnings-expanded-header{display:flex;justify-content:space-between;align-items:center;padding:12px 15px;background:var(--background-primary);border-bottom:1px solid var(--border-color)}.earnings-expanded-title{display:flex;align-items:baseline;gap:10px}.earnings-expanded-title .expanded-ticker{font-size:16px;font-weight:700;color:var(--accent-primary)}.earnings-expanded-title .expanded-name{font-size:13px;color:var(--text-secondary)}.earnings-expanded-actions{display:flex;gap:8px;align-items:center}.earnings-expanded-body{padding:15px;background:var(--background-primary)}.earnings-expanded-body .loading-details{padding:15px;text-align:center;color:var(--text-secondary);font-size:13px}.earnings-expanded-body .details-section{margin-bottom:15px}.earnings-expanded-body .details-section:last-child{margin-bottom:0}.earnings-expanded-body .details-section h4{font-size:13px;font-weight:600;color:var(--text-secondary);margin-bottom:6px}.earnings-expanded-body .details-section p{color:var(--text-primary);line-height:1.5;font-size:13px}.earnings-expanded-body .details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px}.earnings-expanded-body .detail-item{display:flex;flex-direction:column;gap:3px}.earnings-expanded-body .detail-label{font-size:11px;color:var(--text-secondary);font-weight:500}.earnings-expanded-body .detail-value{font-size:13px;color:var(--text-primary);font-weight:600}.earnings-expanded-body .view-company-btn{padding:5px 10px;background:var(--accent-primary);color:#fff;border:none;border-radius:4px;font-size:12px;cursor:pointer;transition:all .2s}.earnings-expanded-body .view-company-btn:hover{background:var(--accent-primary-hover, #1a73e8);transform:translateY(-1px)}.earnings-expanded-body .close-details{padding:3px 6px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-color);border-radius:4px;font-size:14px;cursor:pointer;transition:all .2s}.earnings-expanded-body .close-details:hover{background:var(--background-tertiary);color:var(--text-primary)}.markets-container{padding:20px;min-height:100%;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none;background:transparent;margin-top:20px}.markets-container::-webkit-scrollbar{display:none}.markets-content{display:flex;flex-direction:column;gap:var(--space-6)}.market-status-header{display:flex;align-items:center;gap:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-lg);border:1px solid var(--border-primary)}.market-status-header h2{font-size:var(--font-xl);font-weight:600;margin:0}.status-badge{padding:var(--space-2) var(--space-3);border-radius:var(--radius-md);font-size:var(--font-sm);font-weight:500}.status-badge.open{background:var(--success-light);color:var(--success)}.status-badge.closed{background:var(--error-light);color:var(--error)}.status-badge.extended{background:var(--warning-light);color:var(--warning)}.next-holiday{color:var(--text-secondary);font-size:var(--font-sm)}.market-section{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--border-primary);transition:var(--transition-base)}.market-section:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.market-section h3{font-size:var(--font-lg);font-weight:600;margin:0 0 var(--space-4) 0;color:var(--text-primary);position:relative;padding-left:var(--space-3)}.market-section h3:before{content:"";position:absolute;left:0;top:50%;transform:translateY(-50%);width:4px;height:20px;background:var(--primary);border-radius:2px}.markets-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-5)}.markets-column{display:flex;flex-direction:column;gap:var(--space-5)}.indices-full-width{margin-bottom:var(--space-5)}.indices-combined{grid-column:1 / -1}.indices-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.indices-content{display:flex;flex-direction:column;gap:var(--space-4)}.indices-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:var(--space-3)}.index-card{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-4);border:1px solid var(--border-primary);transition:var(--transition-base);position:relative;overflow:hidden}.index-card:before{content:"";position:absolute;top:0;left:0;width:100%;height:2px;background:linear-gradient(90deg,var(--primary),var(--primary-light));opacity:0;transition:opacity .3s ease}.index-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.index-card:hover:before{opacity:1}.index-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:var(--space-2)}.index-price-section{text-align:right}.index-name{font-size:var(--font-xs);color:var(--text-secondary);margin-bottom:var(--space-1)}.index-ticker{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.index-price{font-size:var(--font-xl);font-weight:700;color:var(--text-primary);margin:var(--space-2) 0}.index-change{font-size:var(--font-sm);font-weight:500;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);display:inline-block}.index-change.positive{background:var(--success-light);color:var(--success)}.index-change.negative{background:var(--error-light);color:var(--error)}.index-volume{font-size:var(--font-xs);color:var(--text-secondary);margin-top:var(--space-2)}.index-sparkline{margin-top:var(--space-2);height:40px;width:100%}.indices-cards-row{display:flex;gap:var(--space-3);flex-wrap:wrap}.index-card-horizontal{flex:1;min-width:250px;display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary)}.index-info{display:flex;flex-direction:column;gap:var(--space-1)}.index-values{text-align:right}.index-timestamp{font-size:var(--font-xs);color:var(--text-secondary);margin-top:var(--space-1)}.etf-label{font-size:var(--font-xs);color:var(--text-secondary)}.change-percent{margin-left:var(--space-1)}.nasdaq-chart-wrapper{position:relative}.nasdaq-label{position:absolute;top:var(--space-3);left:var(--space-3);font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);z-index:1}.sectors-list{display:flex;flex-direction:column;gap:var(--space-2)}.sector-row{display:flex;justify-content:space-between;align-items:center;padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary);transition:var(--transition-base);position:relative;overflow:hidden}.sector-row:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:var(--primary);opacity:0;transition:opacity .3s ease}.sector-row:hover{background:var(--bg-secondary);transform:translate(2px)}.sector-row:hover:before{opacity:1}.sector-name{font-size:var(--font-sm);color:var(--text-primary)}.sector-change{font-size:var(--font-sm);font-weight:600;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm)}.sector-change.positive{background:var(--success-light);color:var(--success)}.sector-change.negative{background:var(--error-light);color:var(--error)}.movers-list,.movers-compact-list{display:flex;flex-direction:column;gap:var(--space-2)}.mover-compact-row{display:grid;grid-template-columns:80px 1fr auto;align-items:center;gap:var(--space-3);padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);cursor:pointer;transition:var(--transition-base)}.mover-compact-row:hover{background:var(--bg-hover);transform:translate(2px)}.mover-ticker{font-weight:600;font-size:var(--font-sm);color:var(--text-primary)}.mover-price{text-align:right;font-size:var(--font-sm);color:var(--text-secondary)}.mover-change{font-size:var(--font-sm);font-weight:600;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);text-align:center;min-width:70px}.mover-change.positive{background:var(--success-light);color:var(--success)}.mover-change.negative{background:var(--error-light);color:var(--error)}.crypto-list{display:flex;flex-direction:column;gap:var(--space-2)}.crypto-row{display:grid;grid-template-columns:1fr auto auto;align-items:center;gap:var(--space-3);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);transition:var(--transition-base)}.crypto-row:hover{background:var(--bg-hover)}.crypto-info{display:flex;flex-direction:column;gap:var(--space-1)}.crypto-name{font-size:var(--font-sm);font-weight:500;color:var(--text-primary)}.crypto-ticker{font-size:var(--font-xs);color:var(--text-secondary)}.crypto-price{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.crypto-change{font-size:var(--font-sm);font-weight:600;padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);text-align:center;min-width:70px}.crypto-change.positive{background:var(--success-light);color:var(--success)}.crypto-change.negative{background:var(--error-light);color:var(--error)}.forex-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:var(--space-2)}.forex-card{padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary);text-align:center;transition:var(--transition-base)}.forex-card:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.forex-pair{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);margin-bottom:var(--space-1)}.forex-rate{font-size:var(--font-lg);font-weight:700;color:var(--text-primary);margin-bottom:var(--space-1)}.forex-change{font-size:var(--font-xs);font-weight:500}.forex-change.positive{color:var(--success)}.forex-change.negative{color:var(--error)}.market-news-section{grid-column:1 / -1}@media (max-width: 768px){.markets-container{padding:var(--space-3)}.markets-grid,.indices-grid{grid-template-columns:1fr}.indices-cards-row{flex-direction:column}.index-card-horizontal{min-width:100%}.forex-grid,.market-news-grid{grid-template-columns:1fr}.market-status h2{font-size:20px}.market-section h3{font-size:18px}.index-price{font-size:20px}.index-change,.sector-name,.sector-change,.mover-ticker,.mover-price,.mover-change,.crypto-name,.crypto-price,.crypto-change,.forex-pair{font-size:16px}.forex-rate{font-size:20px}.forex-change{font-size:14px}}.podcasts-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:var(--space-4)}.podcast-card{background:var(--bg-secondary);border-radius:var(--radius-md);padding:var(--space-4);border:1px solid var(--border-primary);transition:var(--transition-base);display:flex;flex-direction:column;gap:var(--space-3);overflow:hidden;word-wrap:break-word}.podcast-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.podcast-header{display:flex;align-items:center;gap:var(--space-3)}.podcast-artwork{width:60px;height:60px;border-radius:var(--radius-md);object-fit:cover;flex-shrink:0}.podcast-name{font-size:var(--font-sm);font-weight:600;color:var(--primary);margin-bottom:var(--space-1);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.podcast-date{font-size:var(--font-xs);color:var(--text-secondary)}.podcast-title{font-size:var(--font-md);font-weight:600;color:var(--text-primary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.podcast-description{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.5;margin:0}.podcast-audio-player{width:100%;margin:var(--space-3) 0;border-radius:var(--radius-sm);background:var(--bg-tertiary);height:40px}.podcast-audio-player:focus{outline:2px solid var(--primary);outline-offset:2px}.podcast-actions{display:flex;gap:var(--space-2);margin-top:auto}.podcast-play-btn,.podcast-link{padding:var(--space-2) var(--space-3);border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:500;text-decoration:none;transition:var(--transition-base);text-align:center}.podcast-play-btn{background:var(--primary);color:#fff;flex:1;border:none;cursor:pointer;outline:none}.podcast-play-btn:hover{background:var(--primary-dark);transform:translateY(-1px)}.podcast-play-btn:active{transform:translateY(0)}.podcast-link{background:var(--bg-tertiary);color:var(--text-primary);border:1px solid var(--border-primary)}.podcast-link:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.podcasts-loading,.no-podcasts{text-align:center;padding:var(--space-6);color:var(--text-secondary);font-size:var(--font-sm)}@media (max-width: 768px){.podcasts-grid{grid-template-columns:1fr;padding:0 var(--space-2)}.podcast-card{max-width:100%;box-sizing:border-box}.podcast-header{flex-wrap:wrap}.podcast-title{font-size:16px;word-break:break-word}.podcast-description{font-size:14px;word-break:break-word}.podcast-play-btn,.podcast-link{font-size:14px;padding:var(--space-3) var(--space-4);min-height:44px}.podcast-actions{flex-direction:column}.podcast-play-btn,.podcast-link{width:100%}}.videos-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.video-card{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);transition:var(--transition-base)}.video-card:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm);transform:translateY(-2px)}.video-thumbnail-container,.video-player-container{position:relative;width:100%;padding-top:56.25%;background:var(--bg-tertiary);overflow:hidden}.video-player-container{background:#000}.video-iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.video-close-btn{position:absolute;top:10px;right:10px;padding:8px 12px;background:#000c;color:#fff;border:1px solid rgba(255,255,255,.3);border-radius:var(--radius-sm);font-size:var(--font-sm);cursor:pointer;z-index:10;transition:var(--transition-base)}.video-close-btn:hover{background:#000000e6;border-color:#ffffff80}.video-thumbnail{position:absolute;top:0;left:0;width:100%;height:100%;object-fit:cover}.video-play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:60px;height:60px;border-radius:50%;background:#000000b3;border:2px solid white;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:var(--transition-base)}.video-play-overlay:hover{background:#000000e6;transform:translate(-50%,-50%) scale(1.1)}.play-icon{color:#fff;font-size:24px;margin-left:4px}.video-content{padding:var(--space-4)}.video-title{font-size:var(--font-md);font-weight:600;color:var(--text-primary);margin:0 0 var(--space-2) 0;line-height:1.3;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.video-meta{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-2);font-size:var(--font-xs)}.video-channel{color:var(--primary);font-weight:500}.video-date{color:var(--text-secondary)}.video-description{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.4;margin:0}.videos-loading,.no-videos{text-align:center;padding:var(--space-6);color:var(--text-secondary);font-size:var(--font-sm)}@media (max-width: 768px){.videos-grid{grid-template-columns:1fr}.video-title{font-size:16px}.video-description{font-size:14px}.video-meta{font-size:12px}.earnings-calendar-grid{grid-template-columns:1fr;gap:12px}.earnings-day-group{padding:12px}.earnings-company-row{padding:6px 8px}.earnings-ticker{font-size:13px}.earnings-company-name{font-size:11px}.mover-enhanced-row{padding:8px 10px;min-height:60px}.mover-left-section{gap:8px}.mover-percentage-display{font-size:16px;padding:6px 8px;min-width:65px}.mover-ticker{font-size:13px}.mover-name{font-size:11px;max-width:100px}.mover-right-section{gap:10px;flex-wrap:wrap;justify-content:flex-end;max-width:140px}.mover-data-group{min-width:60px}.mover-label{font-size:9px}.mover-value{font-size:11px}.mover-value.small{font-size:10px;max-width:60px}.mover-value.rating{font-size:10px;padding:1px 4px}@media (max-width: 400px){.mover-data-group:nth-child(n+3){display:none}}}.mover-enhanced-row.mover-expanded{background-color:var(--bg-hover);border-color:var(--accent-primary)}.mover-expanded-content{background:var(--bg-secondary);border:1px solid var(--border-primary);border-top:none;margin:-1px 0 8px;animation:expandDown .3s ease-out;overflow:hidden}@keyframes expandDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.mover-expanded-header{display:flex;justify-content:space-between;align-items:center;padding:15px 20px;background:var(--bg-primary);border-bottom:1px solid var(--border-primary)}.mover-expanded-title{display:flex;align-items:baseline;gap:12px}.expanded-ticker{font-size:18px;font-weight:700;color:var(--accent-primary)}.expanded-name{font-size:14px;color:var(--text-secondary)}.expanded-actions{display:flex;gap:10px;align-items:center}.mover-expanded-body{padding:20px;background:var(--bg-primary)}.loading-details{padding:20px;text-align:center;color:var(--text-secondary)}.details-section{margin-bottom:20px}.details-section h4{font-size:14px;font-weight:600;color:var(--text-secondary);margin-bottom:8px}.details-section p{color:var(--text-primary);line-height:1.6;font-size:14px}.details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:15px}.detail-item{display:flex;flex-direction:column;gap:4px}.detail-label{font-size:12px;color:var(--text-secondary);font-weight:500}.detail-value{font-size:14px;color:var(--text-primary);font-weight:600}.view-company-btn{padding:6px 12px;background:var(--accent-primary);color:#fff;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s}.view-company-btn:hover{background:var(--accent-primary-hover, #1a73e8);transform:translateY(-1px)}.ask-modelalpha-btn{padding:6px 12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:13px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:6px;font-weight:500}.ask-modelalpha-btn:hover{background:linear-gradient(135deg,#764ba2,#667eea);transform:translateY(-1px);box-shadow:0 4px 12px #667eea4d}.ask-modelalpha-btn svg{width:20px;height:20px;flex-shrink:0}.ask-modelalpha-btn svg path:last-child{fill:gold;stroke:gold}.close-details{padding:4px 8px;background:transparent;color:var(--text-secondary);border:1px solid var(--border-primary);border-radius:4px;font-size:16px;cursor:pointer;transition:all .2s}.close-details:hover{background:var(--bg-hover);color:var(--text-primary)}@media (max-width: 768px){.mover-expanded-header{flex-direction:column;align-items:flex-start;gap:12px}.expanded-actions{width:100%;justify-content:space-between}.details-grid{grid-template-columns:1fr 1fr}}.company-container{padding:var(--space-4);max-width:1200px;margin:0 auto;overflow-y:auto;height:calc(100vh - 60px)}.company-content{display:flex;flex-direction:column;gap:var(--space-5)}.company-header-extended{background:var(--bg-primary);border-radius:var(--radius-lg);border:1px solid var(--border-primary);overflow:hidden}.company-header{display:flex;justify-content:space-between;align-items:flex-start;padding:var(--space-5);border-bottom:1px solid var(--border-primary)}.company-title{flex:1}.company-title-row{display:flex;align-items:center;gap:var(--space-3)}.company-logo{width:48px;height:48px;border-radius:var(--radius-md);object-fit:contain;padding:var(--space-2);background:#fff;border:1px solid var(--border-primary)}body.dark-mode .company-logo{filter:brightness(.9)}.company-title h1{font-size:var(--font-3xl);font-weight:700;margin:0}.company-title h2{font-size:var(--font-lg);font-weight:400;color:var(--text-secondary);margin:var(--space-2) 0 0 0}.company-title-row+h2{margin-left:60px}.company-description-header{margin-top:var(--space-4);max-width:600px}.company-description-header p{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.6;margin:0;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;position:relative;transition:all .3s ease}.company-description-header p:hover{-webkit-line-clamp:unset;overflow:visible;color:var(--text-primary)}.company-stats{display:flex;gap:var(--space-5);align-items:flex-start}.ask-modelalpha-btn{padding:8px 16px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:6px;font-size:14px;cursor:pointer;transition:all .2s;display:flex;align-items:center;gap:8px;font-weight:500;white-space:nowrap;margin-left:var(--space-4)}.ask-modelalpha-btn:hover{transform:translateY(-1px);box-shadow:0 4px 12px #667eea66}.ask-modelalpha-btn svg{width:16px;height:16px}.stat-item{display:flex;flex-direction:column;gap:var(--space-1)}.stat-label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:var(--font-xl);font-weight:600;color:var(--text-primary)}.stat-value.positive{color:var(--success)}.stat-value.negative{color:var(--error)}.company-info-bar{padding:var(--space-4) var(--space-5);background:var(--bg-secondary)}.company-description-compact{font-size:var(--font-sm);color:var(--text-secondary);line-height:1.6;margin:0 0 var(--space-3) 0;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.company-meta-row{display:flex;gap:var(--space-4);align-items:center;flex-wrap:wrap}.meta-item{font-size:var(--font-sm);color:var(--text-secondary);display:flex;align-items:center;gap:var(--space-1)}.meta-item a{color:var(--primary);text-decoration:none;transition:var(--transition-base)}.meta-item a:hover{text-decoration:underline}.company-card{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--border-primary)}.company-card h3{font-size:var(--font-lg);font-weight:600;margin:0 0 var(--space-4) 0;color:var(--text-primary);display:flex;align-items:center;gap:var(--space-2)}.company-card h4{font-size:var(--font-md);font-weight:600;margin:var(--space-4) 0 var(--space-3) 0;color:var(--text-primary)}.financials-table{overflow-x:auto;margin-bottom:var(--space-4)}.financials-table table{width:100%;border-collapse:collapse}.financials-table th{text-align:left;padding:var(--space-3);font-size:var(--font-sm);font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-primary)}.financials-table td{padding:var(--space-3);font-size:var(--font-sm);border-bottom:1px solid var(--border-primary)}.financials-table td.revenue{color:var(--success);font-weight:600}.financials-table td.net-income{font-weight:600}.financials-table td.net-income.negative{color:var(--error)}.financials-table td.eps{font-weight:600}.financials-table td.eps.negative{color:var(--error)}.financial-chart{margin-top:var(--space-4)}.metric-selector{display:flex;gap:var(--space-2);margin-bottom:var(--space-4)}.metric-selector button{padding:var(--space-2) var(--space-3);background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:var(--radius-md);font-size:var(--font-sm);color:var(--text-primary);cursor:pointer;transition:var(--transition-base)}.metric-selector button:hover{background:var(--bg-hover);border-color:var(--border-secondary)}.metric-selector button.active{background:var(--primary);color:#fff;border-color:var(--primary)}.yahoo-analysis-container{display:flex;flex-direction:column;gap:var(--space-5)}.analysis-ratings-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:var(--space-4)}.recommendation-display{display:flex;flex-direction:column;align-items:center;gap:var(--space-3);padding:var(--space-4)}.recommendation-badge{padding:var(--space-3) var(--space-5);border-radius:var(--radius-lg);font-size:var(--font-xl);font-weight:700;text-transform:uppercase}.recommendation-badge.buy,.recommendation-badge.strong-buy{background:var(--success-light);color:var(--success)}.recommendation-badge.hold{background:var(--warning-light);color:var(--warning)}.recommendation-badge.sell,.recommendation-badge.strong-sell{background:var(--error-light);color:var(--error)}.recommendation-score{font-size:var(--font-sm);color:var(--text-secondary)}.price-target-visual{padding:var(--space-4)}.price-range-bar{position:relative;margin:var(--space-4) 0}.range-track{height:8px;background:var(--bg-secondary);border-radius:4px;position:relative}.range-fill{height:100%;background:linear-gradient(90deg,var(--error),var(--warning),var(--success));border-radius:4px}.current-marker,.target-marker{position:absolute;top:-8px;width:24px;height:24px;background:var(--primary);border:2px solid white;border-radius:50%;transform:translate(-50%)}.marker-label{position:absolute;top:28px;left:50%;transform:translate(-50%);font-size:var(--font-xs);white-space:nowrap}.range-labels{display:flex;justify-content:space-between;margin-top:var(--space-5);font-size:var(--font-sm);color:var(--text-secondary)}.analyst-count{text-align:center;font-size:var(--font-sm);color:var(--text-secondary);margin-top:var(--space-3)}.analyst-earnings-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-4)}.upgrades-downgrades,.earnings-call-video{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--border-primary)}.upgrades-table{overflow-x:auto}.upgrades-table table{width:100%;border-collapse:collapse}.upgrades-table th{text-align:left;padding:var(--space-2);font-size:var(--font-xs);font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-primary)}.upgrades-table td{padding:var(--space-2);font-size:var(--font-sm);border-bottom:1px solid var(--border-primary)}.action{font-weight:600;text-transform:capitalize}.action.upgrade{color:var(--success)}.action.downgrade{color:var(--error)}.action.reiterated,.action.initiated{color:var(--primary)}.video-container{margin-top:var(--space-3)}.video-wrapper{position:relative;padding-bottom:56.25%;height:0;overflow:hidden;border-radius:var(--radius-md)}.video-wrapper iframe{position:absolute;top:0;left:0;width:100%;height:100%;border:none}.video-metadata{margin-top:var(--space-3)}.video-metadata h5{font-size:var(--font-sm);font-weight:600;margin:0 0 var(--space-1) 0}.video-channel{font-size:var(--font-xs);color:var(--text-secondary);margin:0}.video-date{font-size:var(--font-xs);color:var(--text-secondary);margin:var(--space-1) 0 0 0}.video-loading{text-align:center;padding:var(--space-5)}.video-skeleton{width:100%;height:200px;background:var(--bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-3);animation:pulse 2s infinite}.no-video{text-align:center;padding:var(--space-5);color:var(--text-secondary)}.holders-container{margin-top:var(--space-5)}.ownership-breakdown{margin-bottom:var(--space-5)}.ownership-stats{display:grid;gap:var(--space-3);grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-top:var(--space-3)}.ownership-item{display:flex;justify-content:space-between;padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md)}.ownership-label{font-size:var(--font-sm);color:var(--text-secondary)}.ownership-value{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.holders-table,.transactions-table,.roster-table{margin-top:var(--space-3);max-width:100%}.institutional-holders .table-scroll-wrapper{overflow-x:auto}.institutional-holders table{min-width:300px}.insider-transactions .transactions-table .table-scroll-wrapper{max-height:450px;overflow-y:auto;border:0px solid var(--border-primary);border-radius:8px;position:relative;max-width:100%}@media (max-width: 768px){.insider-transactions .transactions-table .table-scroll-wrapper{max-width:320px}}.insider-transactions .transactions-table .table-scroll-wrapper table{min-width:800px;overflow-x:auto}.insider-transactions .transactions-table table thead{position:sticky;top:0;background-color:var(--bg-primary);z-index:10;box-shadow:0 1px 0 var(--border-primary)}.insider-transactions .transactions-table table thead th{background-color:var(--bg-primary)}.institutional-holders table,.insider-transactions table,.insider-roster table{width:100%;border-collapse:collapse}.institutional-holders th,.insider-transactions th,.insider-roster th{text-align:left;padding:var(--space-2);font-size:var(--font-xs);font-weight:600;color:var(--text-secondary);border-bottom:1px solid var(--border-primary);cursor:pointer;-webkit-user-select:none;user-select:none}.institutional-holders td,.insider-transactions td,.insider-roster td{padding:var(--space-2);font-size:var(--font-sm);border-bottom:1px solid var(--border-primary)}.transaction-type{font-weight:600}.transaction-type.buy{color:var(--success)}.transaction-type.sell{color:var(--error)}@media (max-width: 768px){.insider-transactions th:nth-child(5),.insider-transactions td:nth-child(5){display:none}}@media (max-width: 768px){.company-container{padding:var(--space-3);height:calc(100vh - 120px)}.company-header{flex-direction:column;gap:var(--space-4)}.company-description-header{max-width:100%}.company-description-header p{-webkit-line-clamp:4;font-size:var(--font-xs)}.company-stats{width:100%;justify-content:space-between;flex-wrap:wrap}.stat-item{flex:1;align-items:center}.ask-modelalpha-btn{width:100%;margin-top:var(--space-3);margin-left:0;justify-content:center}.company-meta-row{flex-direction:column;align-items:flex-start}.analyst-earnings-grid,.ownership-stats{grid-template-columns:1fr}.nav-tab.company-tab{display:none}}.recommendation-bars{display:flex;flex-direction:column;gap:12px}.rec-row{display:flex;align-items:center;gap:12px}.rec-label{flex:0 0 100px;font-size:var(--font-sm);font-weight:500;color:var(--text-primary)}.rec-bar-container{flex:1;height:20px;background:var(--bg-secondary);border-radius:4px;overflow:hidden}.rec-bar{height:100%;transition:width .3s ease}.rec-bar.buy-strong{background:#047857}.rec-bar.buy{background:#10b981}.rec-bar.hold{background:#fbbf24}.rec-bar.sell{background:#f59e0b}.rec-bar.sell-strong{background:#dc2626}.rec-count{flex:0 0 30px;text-align:right;font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.insider-trading-wrapper{margin-top:var(--space-3);max-width:100%;overflow:hidden}.insider-trading-table{max-width:100%;overflow-x:auto;overflow-y:hidden}.insider-trading-table table{width:700px;border-collapse:collapse}.insider-trading-table th,.insider-trading-table td{padding:var(--space-2);text-align:left;border-bottom:1px solid var(--border-primary)}.insider-trading-table th{font-size:var(--font-xs);font-weight:600;color:var(--text-secondary)}.insider-trading-table td{font-size:var(--font-sm)}.chart-card{position:relative}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:var(--space-4)}.chart-header h3{margin:0}.timeframe-selector{display:flex;gap:var(--space-1);background:var(--bg-secondary);padding:var(--space-1);border-radius:var(--radius-md)}.timeframe-selector.compact{gap:0;padding:0;background:transparent}.timeframe-selector button{padding:var(--space-2) var(--space-3);background:transparent;border:none;border-radius:var(--radius-sm);font-size:var(--font-sm);font-weight:500;color:var(--text-secondary);cursor:pointer;transition:var(--transition-base)}.timeframe-selector button:hover{background:var(--bg-hover);color:var(--text-primary)}.timeframe-selector button.active{background:var(--primary);color:#fff}.timeframe-selector.compact button{padding:var(--space-1) var(--space-2);font-size:var(--font-xs)}.chart-container{position:relative}.chart-change-display{text-align:center;margin-bottom:var(--space-2);padding:var(--space-1) 0}.chart-change-display .change-percentage{font-size:48px;font-weight:700;line-height:1.2;margin-bottom:var(--space-2)}.chart-change-display .current-price{font-size:24px;font-weight:600;line-height:1.4;color:var(--text-primary)}.chart-change-display .change-percentage.positive{color:var(--success-vibrant)}.chart-change-display .change-percentage.negative{color:var(--danger-vibrant)}.chart-change-display .change-value{font-size:18px;font-weight:500;margin-left:var(--space-2)}.chart-loading{display:flex;align-items:center;justify-content:center;height:400px;color:var(--text-secondary);font-size:var(--font-sm)}.chart-area{margin-bottom:var(--space-3)}.chart-stats{display:flex;gap:var(--space-4);padding:var(--space-3);background:var(--bg-secondary);border-radius:var(--radius-md);flex-wrap:wrap;margin-top:-10px}.chart-stat{display:flex;flex-direction:column;gap:var(--space-1);flex:1;min-width:100px}.chart-stat .stat-label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.chart-stat .stat-value{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.chart-stat .stat-value.positive{color:var(--success-vibrant)}.chart-stat .stat-value.negative{color:var(--danger-vibrant)}.index-chart-container{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-4);border:1px solid var(--border-primary)}.index-chart-container .chart-area{border-radius:var(--radius-md);overflow:hidden}.index-chart-stats{display:flex;gap:var(--space-3);padding:var(--space-3) 0;border-top:1px solid var(--border-primary);flex-wrap:wrap}.index-chart-stats .stat-item{display:flex;align-items:baseline;gap:var(--space-2);flex:1;min-width:120px}.index-chart-stats .stat-label{font-size:var(--font-xs);color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.index-chart-stats .stat-value{font-size:var(--font-sm);font-weight:600;color:var(--text-primary)}.index-chart-stats .stat-change{flex:2;min-width:150px}.index-chart-stats .change-percent{font-size:var(--font-lg);font-weight:700}.index-chart-stats .change-percent.positive{color:var(--success-vibrant)}.index-chart-stats .change-percent.negative{color:var(--danger-vibrant)}.index-chart-stats .change-number{font-size:var(--font-sm);color:var(--text-secondary);margin-left:var(--space-1)}.index-chart-stats .stat-current{flex:1.5}.index-chart-stats .stat-current .stat-value{font-size:var(--font-lg);font-weight:700}.index-chart-stats .stat-high-low,.index-chart-stats .stat-volume{flex:1}.recharts-cartesian-axis-tick-value{fill:var(--text-secondary);font-size:11px}.recharts-tooltip-wrapper{outline:none!important}.recharts-default-tooltip{background:var(--bg-primary)!important;border:1px solid var(--border-primary)!important;border-radius:var(--radius-md)!important;box-shadow:var(--shadow-lg)!important}.recharts-tooltip-label{color:var(--text-primary)!important;font-weight:600;margin-bottom:var(--space-2)}.recharts-tooltip-item{color:var(--text-primary)!important}.recharts-cartesian-grid-horizontal line,.recharts-cartesian-grid-vertical line{stroke:var(--border-primary);stroke-dasharray:3 3;opacity:.3}.recharts-xAxis line,.recharts-yAxis line{stroke:var(--border-secondary)}body.dark-mode .recharts-cartesian-axis-tick-value{fill:var(--text-secondary)}body.dark-mode .recharts-default-tooltip{background:var(--bg-primary)!important;border-color:var(--border-primary)!important}body.dark-mode .recharts-tooltip-label,body.dark-mode .recharts-tooltip-item{color:var(--text-primary)!important}@media (max-width: 768px){.chart-change-display .change-percentage{font-size:36px}.chart-change-display .current-price{font-size:20px}.chart-change-display .change-value{font-size:16px}.chart-stats{gap:var(--space-3)}.chart-stat{min-width:80px}.index-chart-stats{flex-direction:column;gap:var(--space-2)}.index-chart-stats .stat-item{width:100%;justify-content:space-between}.timeframe-selector button{padding:var(--space-2);font-size:var(--font-xs)}.chart-loading{height:300px}}.news-section{background:var(--bg-primary);border-radius:var(--radius-lg);padding:var(--space-5);border:1px solid var(--border-primary)}.news-section h3{font-size:var(--font-lg);font-weight:600;margin:0 0 var(--space-4) 0;color:var(--text-primary)}.news-list{display:flex;flex-direction:column;gap:var(--space-4)}.news-item{display:flex;gap:var(--space-4);padding:var(--space-4);background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-primary);transition:var(--transition-base)}.news-item:hover{border-color:var(--border-secondary);box-shadow:var(--shadow-sm)}.news-content{flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.news-header{display:flex;justify-content:space-between;align-items:flex-start;gap:var(--space-3)}.news-header h4{margin:0;font-size:var(--font-md);font-weight:600;line-height:1.4}.news-header h4 a{color:var(--text-primary);text-decoration:none;transition:var(--transition-base)}.news-header h4 a:hover{color:var(--primary)}.news-item p{margin:0;font-size:var(--font-sm);color:var(--text-secondary);line-height:1.6;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.news-meta{display:flex;gap:var(--space-3);align-items:center;font-size:var(--font-xs);color:var(--text-secondary)}.news-publisher{font-weight:500}.news-date,.news-time{color:var(--text-secondary)}.news-ticker-relevance{margin-left:auto;padding:var(--space-1) var(--space-2);background:var(--bg-hover);border-radius:var(--radius-sm);font-weight:500}.news-sentiment{flex-shrink:0}.sentiment-badge{display:inline-flex;align-items:center;gap:var(--space-1);padding:var(--space-1) var(--space-2);border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600;text-transform:uppercase;letter-spacing:.5px}.sentiment-badge.positive{background:var(--success-light);color:var(--success)}.sentiment-badge.negative{background:var(--error-light);color:var(--error)}.sentiment-badge.neutral{background:var(--bg-hover);color:var(--text-secondary)}.news-image-thumb{width:120px;height:80px;object-fit:cover;border-radius:var(--radius-md);flex-shrink:0}.market-news-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-4)}.news-card{background:var(--bg-secondary);border-radius:var(--radius-md);overflow:hidden;border:1px solid var(--border-primary);transition:var(--transition-base)}.news-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md)}.news-link{text-decoration:none;color:inherit;display:flex;flex-direction:column;height:100%}.news-image-container{width:100%;height:160px;overflow:hidden;background:var(--bg-hover)}.news-image-container img{width:100%;height:100%;object-fit:cover;transition:var(--transition-base)}.news-card:hover .news-image-container img{transform:scale(1.05)}.news-card .news-content{padding:var(--space-4);flex:1;display:flex;flex-direction:column;gap:var(--space-2)}.news-title{font-size:var(--font-md);font-weight:600;color:var(--text-primary);margin:0;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis}.news-description{font-size:var(--font-sm);color:var(--text-secondary);margin:0;line-height:1.5;display:-webkit-box;-webkit-line-clamp:3;-webkit-box-orient:vertical;overflow:hidden;text-overflow:ellipsis;flex:1}.news-card .news-meta{margin-top:auto;padding-top:var(--space-2);border-top:1px solid var(--border-primary)}.news-tickers{display:flex;gap:var(--space-1);flex-wrap:wrap;margin-top:var(--space-2)}.news-ticker-badge{padding:var(--space-1);background:var(--primary-light);color:var(--primary);border-radius:var(--radius-sm);font-size:var(--font-xs);font-weight:600}.no-data{text-align:center;padding:var(--space-5);color:var(--text-secondary);font-size:var(--font-sm)}body.dark-mode .news-item,body.dark-mode .news-card{background:var(--bg-secondary)}body.dark-mode .sentiment-badge.positive{background:#10b9811a}body.dark-mode .sentiment-badge.negative{background:#ef44441a}body.dark-mode .sentiment-badge.neutral{background:var(--bg-hover)}@media (max-width: 768px){.news-item{flex-direction:column}.news-image-thumb{width:100%;height:180px}.market-news-grid{grid-template-columns:1fr}.news-header{flex-direction:column;gap:var(--space-2)}.news-meta{flex-wrap:wrap}.news-ticker-relevance{margin-left:0;margin-top:var(--space-1)}}.settings-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:10000;display:flex;align-items:center;justify-content:center;animation:fadeIn .2s ease-in-out}.settings-backdrop{position:absolute;top:0;left:0;right:0;bottom:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.settings-modal{position:relative;background:var(--color-surface);border-radius:12px;box-shadow:0 20px 60px #0000004d;max-width:600px;width:90%;max-height:80vh;overflow-y:auto;animation:slideUp .3s ease-out}.settings-close{position:absolute;top:16px;right:16px;width:36px;height:36px;border-radius:50%;background:var(--color-background);border:1px solid var(--color-border);color:var(--color-text-primary);font-size:24px;font-weight:300;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s;z-index:1}.settings-close:hover{background:var(--color-danger);color:#fff;border-color:var(--color-danger);transform:scale(1.1)}@keyframes slideUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.settings-modal .settings-view{padding-top:20px}@media (max-width: 768px){.settings-modal{width:95%;max-height:90vh;margin:20px}.settings-close{top:12px;right:12px;width:32px;height:32px}}.left-sidebar{position:fixed;left:0;top:0;bottom:0;width:60px;background:var(--bg-primary);border-right:1px solid var(--border-primary);z-index:1000;display:flex;flex-direction:column;justify-content:space-between;padding:12px 0;box-shadow:1px 0 3px #0000000d}.left-sidebar-top{display:flex;flex-direction:column;gap:8px;padding:0 8px}.left-sidebar-logo{width:44px;height:44px;display:flex;align-items:center;justify-content:center;margin-bottom:12px;cursor:pointer;border-radius:10px;transition:background .2s ease}.left-sidebar-logo:hover{background:var(--bg-secondary);box-shadow:0 1px 3px #00000014}.left-sidebar-logo img{width:36px;height:36px;border-radius:8px}.dark-mode .left-sidebar-logo:hover{background:#1a1a1a}.left-sidebar-bottom{display:flex;flex-direction:column;padding:0 8px}.left-sidebar-icon-btn{width:44px;height:44px;padding:10px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:10px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative}.left-sidebar-icon-btn:hover{background:var(--bg-secondary);color:var(--text-primary);box-shadow:0 1px 3px #0000000d}.left-sidebar-icon-btn:active{transform:scale(.95)}.left-sidebar-icon-btn.active{background:transparent;color:#007bff;font-weight:600}.left-sidebar-icon-btn.active:hover{background:var(--bg-secondary);color:#0056b3}.left-sidebar-icon-btn:after{content:attr(title);position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:12px;padding:6px 12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:10001;box-shadow:0 2px 10px #0000001f}.left-sidebar-icon-btn:hover:after{opacity:1}.left-sidebar-icon-btn svg{width:24px;height:24px;flex-shrink:0}.left-sidebar-settings-btn svg{width:20px;height:20px}.dark-mode .left-sidebar{background:#0a0a0a;border-color:#2a2a2a}.dark-mode .left-sidebar-icon-btn{color:#999}.dark-mode .left-sidebar-icon-btn:hover{background:#1a1a1a;color:#fff}.dark-mode .left-sidebar-icon-btn.active{background:transparent;color:#4dabff;font-weight:600}.dark-mode .left-sidebar-icon-btn.active:hover{background:#1a1a1a;color:#3d8fd9}.dark-mode .left-sidebar-icon-btn:after{background:#1a1a1a;border-color:#2a2a2a;box-shadow:0 2px 12px #00000080}@media (max-width: 768px){.left-sidebar{display:flex}}.conversation-sidebar{position:fixed;left:0;top:0;bottom:0;width:280px;background:var(--bg-primary);border-right:1px solid var(--border-primary);z-index:999;display:flex;flex-direction:column;transition:width .2s ease,transform .2s ease}.conversation-sidebar.collapsed{width:60px}@media (max-width: 768px){.conversation-sidebar{transform:translate(-100%)}.conversation-sidebar.open{transform:translate(0)}}@media (max-width: 768px){.conversation-sidebar{top:0;width:85%;max-width:320px;overflow-y:auto}.conversation-sidebar.mobile{box-shadow:2px 0 16px #0000001a}.conversation-sidebar-mobile-header{position:sticky;top:0;background:var(--bg-primary);z-index:10}.conversation-sidebar-header{flex-shrink:1;position:relative}.conversation-sidebar.mobile .conversation-list{overflow-y:visible;flex:none}.conversation-sidebar.mobile .conversation-sidebar-footer{position:sticky;bottom:0;background:var(--bg-primary);z-index:10;border-top:1px solid var(--border-primary)}}.conversation-sidebar-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#00000080;z-index:998}.conversation-sidebar-header{padding:16px 16px 12px;flex-shrink:0}.sidebar-header-title-row{display:flex;align-items:center;justify-content:space-between;gap:12px}.sidebar-title{margin:0;font-size:18px;font-weight:600;color:var(--text-primary);letter-spacing:-.3px}.sidebar-hamburger-btn{width:32px;height:32px;padding:7px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;flex-shrink:0}.sidebar-hamburger-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-hamburger-btn:active{transform:scale(.95)}.sidebar-new-action-btn{width:100%;padding:10px 12px;margin-top:12px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:flex-start;gap:10px;transition:all .2s ease;text-align:left}.sidebar-new-action-btn:hover{background:var(--bg-secondary)}.sidebar-new-action-btn:active{background:var(--bg-tertiary)}.sidebar-new-action-btn svg{flex-shrink:0;color:var(--text-secondary)}.sidebar-new-action-btn:hover svg{color:var(--text-primary)}.sidebar-expand-btn{width:40px;height:40px;padding:10px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:10px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;margin:0 auto}.sidebar-expand-btn:hover{background:var(--bg-secondary);color:var(--text-primary)}.sidebar-expand-btn:active{transform:scale(.95)}.sidebar-search-container{padding:0 16px 12px;flex-shrink:0}.sidebar-search-input-wrapper{position:relative;display:flex;align-items:center}.sidebar-search-icon{position:absolute;left:12px;color:var(--text-secondary);pointer-events:none;z-index:1}.sidebar-search-input{width:100%;padding:8px 12px 8px 36px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:8px;font-size:14px;color:var(--text-primary);cursor:pointer;transition:all .2s ease}.sidebar-search-input:hover{background:var(--bg-hover);border-color:var(--border-hover)}.sidebar-search-input:focus{outline:none;border-color:var(--brand-primary);background:var(--bg-primary)}.sidebar-search-input::placeholder{color:var(--text-secondary)}.sidebar-logo-menu-wrapper{display:flex;align-items:center;gap:10px;padding:8px 4px 12px;margin-bottom:8px}.sidebar-logo-menu-wrapper .logo-menu-button{flex-shrink:0}.conversation-sidebar.collapsed .sidebar-logo-menu-wrapper{justify-content:center;padding:8px 0 12px}.sidebar-logo-menu-wrapper .sidebar-brand-text{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.2px}.conversation-sidebar-mobile-header{display:flex;align-items:center;justify-content:space-between;padding:12px;border-bottom:1px solid var(--border-primary)}.mobile-sidebar-logo{display:flex;align-items:center}.mobile-sidebar-logo img{width:32px;height:32px;border-radius:8px}.mobile-sidebar-close-btn{background:transparent;border:none;padding:8px;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s}.mobile-sidebar-close-btn:hover{background:var(--bg-secondary)}.mobile-sidebar-close-btn:active{background:var(--bg-tertiary)}.sidebar-brand-text{font-size:16px;font-weight:700;color:var(--text-primary);letter-spacing:-.2px}.conversation-sidebar-header-top{display:flex;align-items:center;justify-content:flex-start;margin-bottom:12px}.conversation-sidebar-menu-items{display:flex;flex-direction:column;gap:4px;margin-bottom:8px}.new-conversation-menu-item{flex:1;padding:10px 12px;background:transparent;color:var(--text-primary);border:none;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:flex-start;gap:10px;cursor:pointer;transition:all .2s ease}.new-conversation-menu-item:hover{background:var(--bg-secondary)}.new-conversation-menu-item svg{flex-shrink:0;color:var(--text-secondary)}.new-conversation-menu-item:hover svg{color:var(--text-primary)}.conversation-sidebar-close{padding:8px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s ease;flex-shrink:0;display:flex;align-items:center;justify-content:center}.conversation-sidebar-close:hover{background:var(--bg-secondary);color:var(--text-primary)}.search-menu-item{flex:1;padding:10px 12px;background:transparent;color:var(--text-primary);border:none;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:flex-start;gap:10px;cursor:pointer;transition:all .2s ease}.search-menu-item:hover{background:var(--bg-secondary)}.search-menu-item svg{flex-shrink:0;color:var(--text-secondary)}.search-menu-item:hover svg{color:var(--text-primary)}.chats-menu-item{flex:1;padding:10px 12px;background:transparent;color:var(--text-primary);border:none;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:flex-start;gap:10px;cursor:pointer;transition:all .2s ease}.chats-menu-item:hover{background:var(--bg-secondary)}.chats-menu-item svg{flex-shrink:0;color:var(--text-secondary)}.chats-menu-item:hover svg{color:var(--text-primary)}.new-conversation-icon-only,.search-icon-only,.chats-icon-only,.conversation-sidebar-settings-icon-only{padding:10px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:8px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;width:100%;position:relative}.new-conversation-icon-only:hover,.search-icon-only:hover,.chats-icon-only:hover,.conversation-sidebar-settings-icon-only:hover{background:var(--bg-secondary);color:var(--text-primary)}.new-conversation-icon-only:after,.search-icon-only:after,.chats-icon-only:after,.conversation-sidebar-settings-icon-only:after{content:attr(title);position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:8px;padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1000;box-shadow:0 2px 8px #0000001a}.new-conversation-icon-only:hover:after,.search-icon-only:hover:after,.chats-icon-only:hover:after,.conversation-sidebar-settings-icon-only:hover:after{opacity:1}.new-conversation-btn{width:100%;padding:10px 16px;background:var(--brand-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:500;display:flex;align-items:center;justify-content:center;gap:8px;cursor:pointer;transition:background .2s ease}.new-conversation-btn:hover{background:var(--brand-primary-dark)}.conversation-search{margin-top:12px}.conversation-search-input{width:100%;padding:8px 12px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:6px;font-size:13px;color:var(--text-primary);transition:all .2s ease}.conversation-search-input::placeholder{color:var(--text-tertiary)}.conversation-search-input:focus{outline:none;border-color:var(--brand-primary);background:var(--bg-primary)}.conversation-list{flex:1;overflow-y:auto;padding:8px}.conversation-loading,.conversation-empty{padding:20px;text-align:center;color:var(--text-tertiary);font-size:13px}.conversation-group{margin-bottom:16px}.conversation-group-header{padding:4px 8px;font-size:11px;font-weight:600;text-transform:uppercase;color:var(--text-tertiary);letter-spacing:.5px}.conversation-item{position:relative;display:flex;align-items:center;margin:2px 0;border-radius:6px;transition:background .2s ease}.conversation-item:hover,.conversation-item.active{background:var(--bg-secondary)}.conversation-item-content{flex:1;padding:8px 12px;cursor:pointer;min-width:0}.conversation-title{font-size:14px;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.conversation-date{font-size:11px;color:var(--text-tertiary)}.conversation-rename-container{flex:1;padding:8px 12px}.conversation-rename-input{width:100%;padding:6px 8px;font-size:14px;color:var(--text-primary);background:var(--bg-primary);border:1px solid var(--primary-color);border-radius:4px;outline:none;font-family:inherit}.conversation-rename-input:focus{border-color:var(--primary-color);box-shadow:0 0 0 2px #3b82f61a}.conversation-item.renaming{background:var(--bg-secondary)}.conversation-item.renaming .conversation-menu-btn{display:none}.conversation-menu-container{position:relative;display:flex;align-items:center}.conversation-menu-btn{opacity:0;padding:6px;background:transparent;border:none;color:var(--text-tertiary);cursor:pointer;transition:all .2s ease;border-radius:4px}.conversation-item:hover .conversation-menu-btn{opacity:1}.conversation-menu-btn:hover{background:var(--bg-tertiary);color:var(--text-primary)}.conversation-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.conversation-menu-dropdown{position:absolute;right:0;top:100%;margin-top:4px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:8px;box-shadow:0 4px 12px #00000026;min-width:150px;z-index:1000;overflow:hidden}.conversation-menu-item{width:100%;padding:10px 14px;background:transparent;border:none;color:var(--text-primary);cursor:pointer;display:flex;align-items:center;gap:10px;font-size:14px;text-align:left;transition:all .2s ease}.conversation-menu-item:hover{background:var(--bg-secondary)}.conversation-menu-item.delete{color:var(--error)}.conversation-menu-item.delete:hover{background:#ef44441a}.conversation-menu-item svg{flex-shrink:0}.conversation-delete-confirm-menu{padding:12px}.confirm-message{font-size:13px;color:var(--text-primary);margin-bottom:10px;font-weight:500}.confirm-actions{display:flex;gap:6px}.confirm-delete-btn,.cancel-delete-btn{flex:1;padding:6px 12px;background:transparent;border:1px solid var(--border-primary);cursor:pointer;border-radius:6px;font-size:13px;font-weight:500;transition:all .2s ease}.confirm-delete-btn{color:#fff;background:var(--error);border-color:var(--error)}.confirm-delete-btn:hover{background:#dc2626;border-color:#dc2626}.cancel-delete-btn{color:var(--text-primary)}.cancel-delete-btn:hover{background:var(--bg-secondary)}.dark-mode .conversation-sidebar{background:#0f0f0f;border-color:#2a2a2a}.dark-mode .sidebar-title{color:#f5f5f7}.dark-mode .sidebar-hamburger-btn{color:#999}.dark-mode .sidebar-hamburger-btn:hover{background:#1a1a1a;color:#fff}.dark-mode .sidebar-new-action-btn{color:#f5f5f7}.dark-mode .sidebar-new-action-btn:hover{background:#1a1a1a}.dark-mode .sidebar-new-action-btn:active{background:#222}.dark-mode .sidebar-new-action-btn svg{color:#999}.dark-mode .sidebar-new-action-btn:hover svg{color:#fff}.dark-mode .sidebar-expand-btn{color:#999}.dark-mode .sidebar-expand-btn:hover{background:#1a1a1a;color:#fff}.dark-mode .sidebar-search-input{background:#1a1a1a;border-color:#2a2a2a;color:#f5f5f7}.dark-mode .sidebar-search-input:hover{background:#222;border-color:#333}.dark-mode .sidebar-search-input:focus{border-color:var(--brand-primary);background:#0f0f0f}.dark-mode .sidebar-search-icon{color:#666}.dark-mode .new-conversation-menu-item:hover,.dark-mode .search-menu-item:hover,.dark-mode .chats-menu-item:hover,.dark-mode .conversation-sidebar-close:hover,.dark-mode .sidebar-expand-toggle:hover,.dark-mode .new-conversation-icon-only:hover,.dark-mode .search-icon-only:hover,.dark-mode .chats-icon-only:hover,.dark-mode .conversation-sidebar-settings-icon-only:hover{background:#1a1a1a}.dark-mode .new-conversation-icon-only:after,.dark-mode .search-icon-only:after,.dark-mode .chats-icon-only:after,.dark-mode .conversation-sidebar-settings-icon-only:after{background:#1a1a1a;border-color:#2a2a2a;box-shadow:0 2px 12px #00000080}.dark-mode .conversation-search-input{background:#1a1a1a;border-color:#2a2a2a}.dark-mode .conversation-search-input:focus{background:#0f0f0f;border-color:var(--brand-primary)}.dark-mode .conversation-item:hover,.dark-mode .conversation-item.active{background:#1a1a1a}.conversation-sidebar-footer{padding:12px 8px;border-top:0px solid var(--border-primary);background:transparent;flex-shrink:0;width:100%}.conversation-sidebar.collapsed .conversation-sidebar-footer{margin-top:auto;padding:12px 4px}.conversation-sidebar-user-profile{display:flex;align-items:center;gap:10px;padding:8px 10px;border-radius:10px;cursor:pointer;transition:all .2s ease;background:var(--bg-secondary)!important;margin:0}.conversation-sidebar-user-profile:hover{background:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.user-avatar{position:relative;width:36px;height:36px;flex-shrink:0;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--brand-primary),#6366f1)}.user-avatar .avatar-image{width:100%;height:100%;object-fit:cover;display:block}.user-avatar .avatar-fallback{position:absolute;top:0;left:0;width:100%;height:100%;display:none;align-items:center;justify-content:center;font-size:14px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--brand-primary),#6366f1)}.user-avatar-collapsed{position:relative;width:40px;height:40px;border-radius:50%;overflow:hidden;background:linear-gradient(135deg,var(--brand-primary),#6366f1)}.user-avatar-collapsed .avatar-image{width:100%;height:100%;object-fit:cover;display:block}.user-avatar-collapsed .avatar-fallback{position:absolute;top:0;left:0;width:100%;height:100%;display:none;align-items:center;justify-content:center;font-size:16px;font-weight:600;color:#fff;background:linear-gradient(135deg,var(--brand-primary),#6366f1)}.user-profile-info{flex:1;min-width:0}.user-profile-name{font-size:14px;font-weight:600;color:#fff;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.user-profile-email{font-size:11px;color:#fffc;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.conversation-sidebar-settings-btn{padding:8px;background:transparent;border:none;color:#fffc;cursor:pointer;border-radius:6px;transition:all .2s ease;flex-shrink:0}.conversation-sidebar-settings-btn:hover{background:#ffffff26;color:#fff}.conversation-sidebar-avatar-only{width:52px;padding:6px;background:var(--brand-primary);border:none;cursor:pointer;border-radius:10px;transition:all .2s ease;display:flex;align-items:center;justify-content:center;position:relative;margin:0 auto}.conversation-sidebar-avatar-only:hover{background:var(--brand-primary-dark);transform:translateY(-1px);box-shadow:0 2px 8px #3b82f64d}.conversation-sidebar-avatar-only:after{content:attr(title);position:absolute;left:100%;top:50%;transform:translateY(-50%);margin-left:8px;padding:6px 10px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:6px;font-size:12px;font-weight:500;color:var(--text-primary);white-space:nowrap;opacity:0;pointer-events:none;transition:opacity .2s ease;z-index:1000;box-shadow:0 2px 8px #0000001a}.conversation-sidebar-avatar-only:hover:after{opacity:1}.dark-mode .conversation-sidebar-footer{background:transparent;border-color:#2a2a2a}.dark-mode .conversation-sidebar-user-profile{background:var(--brand-primary)}.dark-mode .conversation-sidebar-user-profile:hover{background:var(--brand-primary-dark)}.dark-mode .conversation-sidebar-settings-btn:hover{background:#ffffff26}.dark-mode .conversation-sidebar-avatar-only{background:var(--brand-primary)}.dark-mode .conversation-sidebar-avatar-only:hover{background:var(--brand-primary-dark)}.dark-mode .conversation-sidebar-avatar-only:after{background:#1a1a1a;border-color:#2a2a2a;box-shadow:0 2px 12px #00000080}@media (min-width: 769px){.conversation-sidebar{transform:translate(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.logo-menu-button{display:none!important}@media (min-width: 769px){.logo-menu-button{display:flex!important;align-items:center;justify-content:center;position:relative;width:44px;height:44px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:10px;cursor:pointer;transition:all .3s ease;box-shadow:0 2px 8px #0000001a;overflow:hidden}.logo-menu-button:hover{background:var(--bg-secondary);box-shadow:0 4px 12px #00000026;transform:scale(1.05)}.logo-menu-button:active{transform:scale(.95)}.logo-menu-button-logo,.logo-menu-button-menu{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);transition:opacity .3s ease;display:flex;align-items:center;justify-content:center}.logo-menu-button-logo{opacity:1}.logo-menu-button-logo img{width:32px;height:32px;border-radius:6px}.logo-menu-button-menu{opacity:0;color:var(--text-secondary)}.logo-menu-button:hover .logo-menu-button-logo{opacity:0}.logo-menu-button:hover .logo-menu-button-menu{opacity:1;color:var(--text-primary)}.dark-mode .logo-menu-button{background:#1a1a1a;border-color:#2a2a2a}.dark-mode .logo-menu-button:hover{background:#2a2a2a}}.chat-header-desktop{display:none}.expanded-panel{background:var(--bg-primary);z-index:1000;display:flex;flex-direction:column}.expanded-panel.mobile{position:fixed;top:0;bottom:0;left:0;right:0;transform:translateY(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);border-top-left-radius:16px;border-top-right-radius:16px;box-shadow:0 -4px 12px #00000014}.expanded-panel.mobile.open{transform:translateY(0);transition:transform .3s cubic-bezier(.4,0,.2,1)}.mobile-drag-handle{width:100%;padding:12px 0 8px;display:flex;justify-content:center;align-items:center;cursor:grab;touch-action:none;flex-shrink:0}.mobile-drag-handle:active{cursor:grabbing}.mobile-drag-indicator{width:40px;height:4px;background:var(--border-color);border-radius:2px;opacity:.5}.expanded-panel.desktop{position:fixed;top:0;right:0;bottom:0;height:100vh;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-4px 0 12px #0000000d;border-left:1px solid var(--border-color)}.expanded-panel.desktop.open{transform:translate(0)}.expanded-panel.embedded{position:relative;width:100%;height:100%;transform:none;box-shadow:none;border:none}.expanded-panel.embedded.open{transform:none}.expanded-resize-handle{position:absolute;left:-4px;top:0;bottom:0;width:8px;cursor:ew-resize;background:transparent;transition:all .2s;z-index:10;display:flex;align-items:center;justify-content:center}.expanded-resize-handle:after{content:"";width:2px;height:100%;background:var(--border-color, rgba(0, 0, 0, .1));transition:background-color .2s}.expanded-resize-handle:hover{background:#3b82f60d}.expanded-resize-handle:hover:after{background:#3b82f680;width:3px}.expanded-resize-handle.dragging{background:#3b82f61a}.expanded-resize-handle.dragging:after{background:#3b82f6cc;width:3px}.expanded-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#00000080;z-index:999;animation:fadeIn .3s ease}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.expanded-header{display:flex;align-items:center;justify-content:space-between;padding:16px 20px;border-bottom:1px solid var(--border-color);background:var(--bg-primary);flex-shrink:0}.expanded-title-section{display:flex;align-items:center;gap:12px;flex:1;min-width:0}.expanded-icon{font-size:24px;flex-shrink:0}.expanded-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.expanded-close-btn{background:var(--bg-secondary);border:none;width:36px;height:36px;border-radius:8px;display:flex;align-items:center;justify-content:center;cursor:pointer;transition:background-color .2s;flex-shrink:0}.expanded-close-btn:hover{background:var(--bg-tertiary)}.expanded-body{flex:1;overflow-y:auto;padding:20px}.expanded-body.no-padding{padding:0}.expanded-chart,.expanded-table,.expanded-model-table,.expanded-model-builder,.expanded-market-report{width:100%;height:100%}.expanded-portfolio{width:100%;height:100%;overflow-y:auto}.expanded-model{width:100%}.portfolio-simple-view{padding:20px}.portfolio-simple-view .portfolio-header{display:flex;align-items:center;gap:12px;margin-bottom:20px}.portfolio-simple-view .portfolio-header h2{margin:0;font-size:24px;color:var(--text-primary)}.portfolio-simple-view .portfolio-type{background:var(--bg-tertiary);padding:4px 12px;border-radius:12px;font-size:14px;color:var(--text-secondary)}.portfolio-simple-view .portfolio-description{color:var(--text-secondary);margin-bottom:20px;line-height:1.5}.portfolio-simple-view .portfolio-value,.portfolio-simple-view .portfolio-holdings{display:flex;justify-content:space-between;padding:12px 0;border-bottom:1px solid var(--border-color);font-size:16px}.portfolio-simple-view .portfolio-value span,.portfolio-simple-view .portfolio-holdings span{color:var(--text-secondary)}.portfolio-simple-view .portfolio-value strong,.portfolio-simple-view .portfolio-holdings strong{color:var(--text-primary);font-weight:600}.portfolio-simple-view .portfolio-message{margin-top:30px;padding:16px;background:var(--bg-secondary);border-radius:8px;text-align:center}.portfolio-simple-view .portfolio-message p{margin:0;color:var(--text-secondary);font-size:14px}.expanded-chart{min-height:400px}.expanded-table,.expanded-model-table{background:var(--bg-primary);border-radius:8px;padding:16px}.expanded-actions{padding:16px 20px;border-top:1px solid var(--border-color);background:var(--bg-primary);display:flex;gap:12px;justify-content:flex-end}.save-model-btn,.model-saved-btn{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:500;border:none;cursor:pointer;transition:background-color .2s;display:flex;align-items:center;gap:8px}.save-model-btn{background:var(--primary);color:#fff}.save-model-btn:hover{background:var(--primary-hover)}.model-saved-btn{background:var(--success-bg);color:var(--success);cursor:default}.coming-soon{text-align:center;color:var(--text-secondary);font-style:italic;margin:40px 0}@media (max-width: 768px){.expanded-header{padding:12px 16px}.expanded-body{padding:16px}.expanded-title{font-size:16px}}@media (prefers-color-scheme: dark){.expanded-panel{background:var(--bg-primary)}.expanded-overlay{background:#000000b3}.expanded-resize-handle:hover{background:var(--primary-color)}}.chat-container{transition:margin-right .3s cubic-bezier(.4,0,.2,1),margin-left .3s ease;position:relative;box-sizing:border-box}.expanded-panel.desktop{position:fixed;z-index:1000}@media (min-width: 769px){.chat-container.with-expanded-panel{flex:initial!important;width:auto!important}}.groups-sidebar-container{display:flex;flex-direction:column;height:100%;overflow:hidden}.groups-sidebar-header{padding:12px;border-bottom:1px solid var(--border-primary);flex-shrink:0}.create-group-btn{width:100%;display:flex;align-items:center;justify-content:center;gap:8px;padding:10px 16px;background:var(--accent-primary);color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.create-group-btn:hover{background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 2px 8px #2563eb4d}.create-group-btn svg{flex-shrink:0}.groups-list{flex:1;overflow-y:auto;padding:8px}.groups-loading{padding:20px;text-align:center;color:var(--text-secondary);font-size:14px}.groups-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:40px 20px;text-align:center;color:var(--text-secondary)}.groups-empty-icon{margin-bottom:16px;opacity:.5}.groups-empty-icon svg{color:var(--text-secondary)}.groups-empty p{margin:0 0 8px;font-size:16px;font-weight:500;color:var(--text-primary)}.groups-empty-subtitle{font-size:14px!important;color:var(--text-secondary)!important;max-width:220px}.group-item{display:flex;align-items:center;gap:12px;padding:10px;border-radius:8px;cursor:pointer;transition:all .2s ease;margin-bottom:4px;position:relative}.group-item:hover{background:var(--bg-hover)}.group-item.active{background:var(--accent-primary);color:#fff}.group-item.active .group-name,.group-item.active .group-meta{color:#fff}.group-item.active .admin-badge{color:#ffffffe6}.group-avatar{position:relative;width:44px;height:44px;border-radius:12px;overflow:hidden;flex-shrink:0;background:var(--accent-primary)}.group-avatar img{width:100%;height:100%;object-fit:cover}.group-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:16px;font-weight:700;color:#fff;background:var(--accent-primary)}.group-unread-badge{position:absolute;top:-4px;right:-4px;background:#ef4444;color:#fff;font-size:10px;font-weight:700;padding:2px 6px;border-radius:10px;min-width:18px;height:18px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 4px #0003}.group-info{flex:1;min-width:0}.group-name-row{display:flex;align-items:center;gap:6px;margin-bottom:4px}.group-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;flex:1}.admin-badge{flex-shrink:0;color:var(--accent-primary);display:flex;align-items:center}.group-meta{display:flex;align-items:center;gap:6px;font-size:12px;color:var(--text-secondary)}.group-members,.group-activity{white-space:nowrap}.group-separator{color:var(--text-tertiary)}.group-menu-container{position:relative;flex-shrink:0}.group-menu-btn{padding:6px;background:transparent;border:none;border-radius:6px;cursor:pointer;color:var(--text-secondary);display:flex;align-items:center;justify-content:center;transition:all .2s ease;opacity:0}.group-item:hover .group-menu-btn{opacity:1}.group-menu-btn:hover{background:var(--bg-hover);color:var(--text-primary)}.group-menu-overlay{position:fixed;top:0;left:0;right:0;bottom:0;z-index:999}.group-menu-dropdown{position:absolute;top:100%;right:0;margin-top:4px;background:#fff;border:1px solid #e5e5e5;border-radius:8px;box-shadow:0 4px 16px #0003;min-width:180px;z-index:1000;overflow:hidden}.group-menu-item{width:100%;display:flex;align-items:center;gap:10px;padding:10px 14px;background:transparent;border:none;cursor:pointer;color:#1d1d1f;font-size:14px;text-align:left;transition:background .2s ease}.group-menu-item:hover{background:#f5f5f5}.group-menu-item svg{flex-shrink:0;color:#6e6e73}.dark-mode .group-menu-dropdown{background:#2d2d2d;border:1px solid #404040;box-shadow:0 4px 16px #00000080}.dark-mode .group-menu-item{color:#f5f5f7}.dark-mode .group-menu-item:hover{background:#3d3d3d}.dark-mode .group-menu-item svg{color:#a1a1a6}.pending-invitations-notification{background:#fef3c7;border-bottom:1px solid #f59e0b;flex-shrink:0}.invitations-banner{width:100%;display:flex;align-items:center;justify-content:space-between;padding:12px;background:transparent;border:none;cursor:pointer;text-align:left}.invitations-banner-content{display:flex;align-items:center;gap:10px;color:#92400e;font-size:14px;font-weight:500}.invitations-banner-content svg{color:#f59e0b;flex-shrink:0}.expand-icon{color:#92400e;transition:transform .2s ease;flex-shrink:0}.expand-icon.expanded{transform:rotate(180deg)}.invitations-list{border-top:1px solid #f59e0b;background:#fffbeb;max-height:300px;overflow-y:auto}.invitations-loading,.invitations-empty{padding:16px;text-align:center;color:#92400e;font-size:13px}.invitation-item{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px;border-bottom:1px solid #fde68a}.invitation-item:last-child{border-bottom:none}.invitation-info{flex:1;min-width:0}.invitation-group-name{font-size:14px;font-weight:600;color:#92400e;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.invitation-inviter{font-size:12px;color:#b45309}.invitation-actions{display:flex;gap:6px;flex-shrink:0}.invitation-accept-btn,.invitation-decline-btn{padding:6px 12px;font-size:12px;font-weight:600;border-radius:6px;border:none;cursor:pointer;transition:all .2s ease}.invitation-accept-btn{background:#10b981;color:#fff}.invitation-accept-btn:hover{background:#059669}.invitation-decline-btn{background:#fff;color:#92400e;border:1px solid #d97706}.invitation-decline-btn:hover{background:#fef3c7}.modal-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background:#000000b3;display:flex;align-items:center;justify-content:center;z-index:10000;padding:20px;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px)}.modal-content{background:#fff;border-radius:12px;border:1px solid #e5e5e5;box-shadow:0 20px 60px #0000004d;max-width:500px;width:100%;max-height:90vh;overflow:hidden;display:flex;flex-direction:column}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:20px 24px;border-bottom:1px solid #e5e5e5;background:#fafafa}.modal-header h2{margin:0;font-size:20px;font-weight:700;color:#1d1d1f}.modal-close-btn{padding:8px;background:transparent;border:none;color:#6e6e73;cursor:pointer;border-radius:6px;transition:all .2s ease}.modal-close-btn:hover{background:#f0f0f0;color:#1d1d1f}.modal-body{padding:24px;overflow-y:auto;flex:1;background:#fff}.modal-description{margin:0 0 20px;font-size:15px;color:#6e6e73;line-height:1.5}.create-type-option{display:flex;align-items:center;gap:16px;width:100%;padding:16px;margin-bottom:12px;background:#fafafa;border:1px solid #e5e5e5;border-radius:12px;cursor:pointer;transition:all .2s ease;text-align:left}.create-type-option:last-child{margin-bottom:0}.create-type-option:hover{background:#f0f0f0;border-color:#d1d1d6;transform:translateY(-1px);box-shadow:0 4px 12px #00000014}.create-type-option:active{transform:translateY(0)}.create-type-icon{flex-shrink:0;width:48px;height:48px;display:flex;align-items:center;justify-content:center;background:#fff;border-radius:10px;border:1px solid #e5e5e5;color:var(--accent-primary)}.create-type-content{flex:1;min-width:0}.create-type-title{margin:0 0 4px;font-size:16px;font-weight:600;color:#1d1d1f}.create-type-description{margin:0;font-size:13px;color:#6e6e73;line-height:1.4}.create-type-arrow{flex-shrink:0;color:#a1a1a6;transition:transform .2s ease}.create-type-option:hover .create-type-arrow{transform:translate(2px);color:#6e6e73}.form-group{margin-bottom:20px}.form-group label{display:block;margin-bottom:8px;font-size:14px;font-weight:600;color:var(--text-primary)}.form-group .required{color:var(--error-color)}.form-input,.form-select{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-primary);background:var(--bg-primary)!important;transition:all .2s ease}.form-input:focus,.form-select:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb1a}.form-input:disabled,.form-select:disabled{opacity:.6;cursor:not-allowed}.form-hint{margin-top:6px;font-size:12px;color:var(--text-secondary)}.avatar-preview{margin-top:16px;display:flex;align-items:center;gap:12px}.avatar-preview-label{font-size:14px;font-weight:600;color:var(--text-primary)}.avatar-preview-image{width:60px;height:60px;border-radius:12px;object-fit:cover;border:2px solid var(--border-primary)}.modal-footer{display:flex;justify-content:flex-end;gap:12px;padding:20px 24px;border-top:1px solid var(--border-primary)}.btn-primary,.btn-secondary{padding:10px 20px;font-size:14px;font-weight:600;border-radius:8px;border:none;cursor:pointer;transition:all .2s ease}.btn-primary{background:var(--accent-primary);color:#fff}.btn-primary:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px);box-shadow:0 2px 8px #2563eb4d}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-secondary{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-primary)}.btn-secondary:hover:not(:disabled){background:var(--bg-hover)}.btn-secondary:disabled{opacity:.6;cursor:not-allowed}.dark-mode .groups-empty{color:#999}.dark-mode .group-item:hover{background:#1a1a1a}.dark-mode .group-item.active{background:var(--accent-primary)}.dark-mode .modal-overlay{background:#000000d9}.dark-mode .modal-content{background:#1e1e1e;border:1px solid #3a3a3a;box-shadow:0 20px 60px #000000b3}.dark-mode .modal-header{border-color:#3a3a3a;background:#252525}.dark-mode .modal-header h2{color:#f5f5f7}.dark-mode .modal-close-btn{color:#a1a1a6}.dark-mode .modal-close-btn:hover{background:#2d2d2d;color:#f5f5f7}.dark-mode .modal-body{background:#1e1e1e}.dark-mode .modal-description{color:#a1a1a6}.dark-mode .create-type-option{background:#252525;border-color:#3a3a3a}.dark-mode .create-type-option:hover{background:#2d2d2d;border-color:#4a4a4a}.dark-mode .create-type-icon{background:#1e1e1e;border-color:#3a3a3a}.dark-mode .create-type-title{color:#f5f5f7}.dark-mode .create-type-description{color:#a1a1a6}.dark-mode .create-type-arrow{color:#6e6e73}.dark-mode .create-type-option:hover .create-type-arrow{color:#a1a1a6}.dark-mode .modal-footer{border-color:#3a3a3a;background:#1e1e1e}body.dark-mode .form-group label{color:var(--text-primary)}body.dark-mode .form-input,body.dark-mode .form-select{background:var(--bg-secondary)!important;border-color:var(--border-color);color:var(--text-primary)}body.dark-mode .form-input:focus,body.dark-mode .form-select:focus{border-color:var(--accent-primary);background:var(--bg-primary)!important;box-shadow:0 0 0 3px #4dabff1a}.dark-mode .btn-secondary{background:#1a1a1a;border-color:#2a2a2a;color:#fff}.dark-mode .btn-secondary:hover:not(:disabled){background:#2a2a2a}.modal-large{max-width:600px}.modal-tabs{display:flex;border-bottom:1px solid var(--border-primary);background:var(--bg-secondary)}.modal-tab{flex:1;padding:14px 20px;background:transparent;border:none;border-bottom:2px solid transparent;color:var(--text-secondary);font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.modal-tab:hover{color:var(--text-primary);background:var(--bg-hover)}.modal-tab.active{color:var(--accent-primary);border-bottom-color:var(--accent-primary);background:var(--bg-primary)}.form-textarea{width:100%;padding:10px 12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;color:var(--text-primary);background:var(--bg-primary)!important;font-family:inherit;resize:vertical;transition:all .2s ease}.form-textarea:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px #2563eb1a}.form-textarea:disabled{opacity:.6;cursor:not-allowed}.members-tab{padding:20px 0}.invite-members-btn{width:100%;margin-bottom:20px;display:flex;align-items:center;justify-content:center;gap:8px}.members-list{display:flex;flex-direction:column;gap:8px}.member-item{display:flex;align-items:center;justify-content:space-between;padding:12px;background:#f8f8f8;border-radius:8px;border:1px solid #e5e5e5;margin-bottom:.5rem;transition:background .2s ease}.member-item:hover{background:#f0f0f0}.member-info{flex:1;min-width:0}.member-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:2px}.member-email{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.member-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.member-admin-badge{padding:4px 10px;background:var(--accent-primary);color:#fff;font-size:11px;font-weight:700;border-radius:12px;text-transform:uppercase;letter-spacing:.5px}.btn-danger-small{padding:6px 12px;font-size:12px;font-weight:600;background:#ef4444;color:#fff;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-danger-small:hover{background:#dc2626}.admin-tab{padding:20px 0}.admin-section{margin-bottom:32px;padding-bottom:32px;border-bottom:1px solid var(--border-primary)}.admin-section:last-child{margin-bottom:0;padding-bottom:0;border-bottom:none}.admin-section h3{margin:0 0 8px;font-size:16px;font-weight:700;color:var(--text-primary)}.admin-section-description{margin:0 0 16px;font-size:14px;color:var(--text-secondary);line-height:1.5}.danger-section{border-color:#fecaca;background:#fef2f2;padding:20px;border-radius:8px}.danger-section h3{color:#dc2626}.btn-danger{padding:10px 20px;font-size:14px;font-weight:600;background:#ef4444;color:#fff;border:none;border-radius:8px;cursor:pointer;transition:all .2s ease}.btn-danger:hover{background:#dc2626;transform:translateY(-1px);box-shadow:0 2px 8px #ef44444d}.info-message{padding:12px 16px;background:#eff6ff;border:1px solid #bfdbfe;border-radius:8px;color:#1e40af;font-size:14px;margin-top:16px}.dark-mode .modal-tabs{background:#0a0a0a;border-color:#2a2a2a}.dark-mode .modal-tab{color:#999}.dark-mode .modal-tab:hover{color:#fff;background:#1a1a1a}.dark-mode .modal-tab.active{background:#0a0a0a;color:var(--accent-primary)}body.dark-mode .form-textarea{background:var(--bg-secondary)!important;border-color:var(--border-color);color:var(--text-primary)}body.dark-mode .form-textarea:focus{border-color:var(--accent-primary);background:var(--bg-primary)!important;box-shadow:0 0 0 3px #4dabff1a}.dark-mode .member-item{background:#2a2a2a;border-color:#3a3a3a}.dark-mode .member-item:hover{background:#333}.dark-mode .danger-section{background:#1a0a0a;border-color:#3a0a0a}.dark-mode .info-message{background:#0a1a2a;border-color:#1a3a5a;color:#60a5fa}.group-chat-view{display:flex;flex-direction:column;height:100%;background:var(--bg-primary);max-width:900px;margin:0 auto}.mobile-group-header{display:flex;align-items:center;padding:12px 16px;background:var(--bg-primary);position:sticky;top:0;z-index:100;gap:12px;flex-shrink:0}.mobile-hamburger-btn{background:transparent;border:none;padding:8px;cursor:pointer;color:var(--text-primary);display:flex;align-items:center;justify-content:center;border-radius:8px;transition:background-color .2s;flex-shrink:0}.mobile-hamburger-btn:hover{background:var(--bg-secondary)}.mobile-hamburger-btn:active{background:var(--bg-tertiary)}.mobile-group-header-info{display:flex;align-items:center;gap:10px;flex:1;min-width:0}.mobile-group-avatar{width:36px;height:36px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--accent-primary)}.mobile-group-avatar img{width:100%;height:100%;object-fit:cover}.mobile-group-header-text{flex:1;min-width:0}.mobile-header-title{font-size:15px;font-weight:600;color:var(--text-primary);overflow:hidden;text-overflow:ellipsis;white-space:nowrap;margin-bottom:1px;line-height:1.2}.mobile-header-members{font-size:11px;color:var(--text-secondary);line-height:1.2}.group-chat-view.loading{justify-content:center;align-items:center}.group-chat-loading{padding:40px;text-align:center;color:var(--text-secondary);font-size:16px}.group-chat-header{display:flex;align-items:center;justify-content:space-between;gap:12px;padding:12px 16px;flex-shrink:0}.group-back-btn{padding:8px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s ease;flex-shrink:0}.group-back-btn:hover{color:var(--text-primary)}.group-chat-header-info{display:flex;align-items:center;gap:12px;min-width:0}.group-chat-header-avatar{width:40px;height:40px;border-radius:10px;overflow:hidden;flex-shrink:0;background:var(--accent-primary)}.group-chat-header-avatar img{width:100%;height:100%;object-fit:cover}.group-chat-header-text{flex:1;min-width:0}.group-chat-header-name{font-size:16px;font-weight:700;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.group-chat-header-members{font-size:12px;color:var(--text-secondary)}.group-settings-btn{padding:8px;background:transparent;border:none;color:var(--text-secondary);cursor:pointer;border-radius:6px;transition:all .2s ease;flex-shrink:0}.group-settings-btn:hover{color:var(--text-primary)}.group-message-list{padding:20px;background:var(--bg-primary);width:100%}.group-message-list.empty{display:flex;align-items:center;justify-content:center}.group-messages-empty{text-align:center;color:var(--text-secondary);padding:40px 20px}.group-messages-empty svg{margin-bottom:16px;opacity:.5}.group-messages-empty p{margin:0 0 8px;font-size:16px;font-weight:500;color:var(--text-primary)}.empty-subtitle{font-size:14px!important;color:var(--text-secondary)!important}.group-messages-container{margin:0 auto}.message-date-group{margin-bottom:24px}.message-date-divider{display:flex;align-items:center;margin:24px 0 16px;text-align:center}.message-date-divider:before,.message-date-divider:after{content:"";flex:1;border-bottom:1px solid var(--border-primary)}.message-date-divider span{padding:0 16px;font-size:12px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.5px}.group-message{display:flex;gap:12px;margin-bottom:4px;padding:4px 8px;border-radius:8px;transition:background .2s ease}.group-message:hover{background:var(--bg-hover)}.group-message.own-message{flex-direction:row-reverse}.group-message.show-avatar{margin-top:12px}.message-avatar{width:36px;height:36px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--accent-primary)}.message-avatar img{width:100%;height:100%;object-fit:cover}.message-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:14px;font-weight:700;color:#fff}.group-message:not(.show-avatar) .message-avatar{visibility:hidden}.message-content-wrapper{flex:1;min-width:0;max-width:100%}.group-message.own-message .message-content-wrapper{display:flex;flex-direction:column;align-items:flex-end;max-width:70%;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.message-sender-name{font-size:13px;font-weight:600;color:var(--text-primary);margin-bottom:4px;padding:0 12px}.message-bubble{display:inline-block;padding:10px 14px;border-radius:16px;background:var(--bg-secondary);border:1px solid var(--border-primary);word-wrap:break-word;max-width:100%;color:var(--text-primary);box-shadow:var(--shadow-sm);user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.group-message.own-message .message-bubble{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.message-text{font-size:14px;line-height:1.5;margin-bottom:4px;white-space:pre-wrap;user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.message-text *{user-select:text;-webkit-user-select:text;-moz-user-select:text;-ms-user-select:text}.message-text h1,.message-text h2,.message-text h3{margin-top:12px;margin-bottom:6px;font-weight:600;line-height:1.3}.message-text h1{font-size:1.5em}.message-text h2{font-size:1.3em}.message-text h3{font-size:1.1em}.message-text h1:first-child,.message-text h2:first-child,.message-text h3:first-child{margin-top:0}.message-text p{margin:6px 0;line-height:1.5}.message-text p:first-child{margin-top:0}.message-text p:last-child{margin-bottom:0}.message-text strong{font-weight:700}.message-text em{font-style:italic}.message-text ul,.message-text ol{margin:8px 0;padding-left:20px}.message-text li{margin:3px 0;line-height:1.5}.message-text code{background:#0000001a;padding:2px 4px;border-radius:3px;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:.9em}.group-message.own-message .message-text code{background:#fff3}.message-text pre{background:#0000000d;border-radius:6px;padding:8px;margin:8px 0;overflow-x:auto}.group-message.own-message .message-text pre{background:#ffffff26}.message-text pre code{background:transparent;padding:0;font-family:SF Mono,Monaco,Consolas,Courier New,monospace;font-size:.85em;line-height:1.4}.message-text a{color:#06c;text-decoration:underline;cursor:pointer;pointer-events:auto;transition:opacity .2s ease}.message-text a:hover{opacity:.8;text-decoration:underline}.group-message.own-message .message-text a{color:#e0f0ff}.group-message.own-message .message-text a:hover{opacity:.9}.group-message.own-message .message-text{color:#fff}.group-message.own-message .message-time{color:#fffc}.group-message.own-message .message-bubble ::selection{background:#ffffff4d;color:#fff}.group-message.own-message .message-bubble ::-moz-selection{background:#ffffff4d;color:#fff}.group-message .message-bubble .message-text .mention,.group-message.own-message .message-bubble .message-text .mention,.group-message.other-message .message-bubble .message-text .mention,.group-message.ai-message .message-bubble .message-text .mention,.group-message .message-bubble .message-text .mention-me,.group-message.own-message .message-bubble .message-text .mention-me,.group-message.other-message .message-bubble .message-text .mention-me,.group-message.ai-message .message-bubble .message-text .mention-me{background:transparent!important;color:#25d366!important;padding:0!important;border-radius:0!important;font-weight:700!important}.group-message .message-bubble .message-text .mention-ai{background:transparent!important;color:#1e40af!important;padding:0!important;border-radius:0!important;font-weight:700!important}.group-message.own-message .message-bubble .message-text .mention-ai{background:transparent!important;color:#fff!important;padding:0!important;border-radius:0!important;font-weight:700!important}.group-message.other-message .message-bubble .message-text .mention-ai,.group-message.ai-message .message-bubble .message-text .mention-ai{background:transparent!important;color:#1e40af!important;padding:0!important;border-radius:0!important;font-weight:700!important}.dark-mode .group-message .message-bubble .message-text .mention,.dark-mode .group-message .message-bubble .message-text .mention-me,body.dark-mode .group-message .message-bubble .message-text .mention,body.dark-mode .group-message .message-bubble .message-text .mention-me{color:#25d366!important}.dark-mode .group-message .message-bubble .message-text .mention-ai,body.dark-mode .group-message .message-bubble .message-text .mention-ai{color:#60a5fa!important}.dark-mode .group-message.own-message .message-bubble .message-text .mention-ai,body.dark-mode .group-message.own-message .message-bubble .message-text .mention-ai{color:#fff!important}.dark-mode .group-message.other-message .message-bubble .message-text .mention-ai,body.dark-mode .group-message.other-message .message-bubble .message-text .mention-ai,.dark-mode .group-message.ai-message .message-bubble .message-text .mention-ai,body.dark-mode .group-message.ai-message .message-bubble .message-text .mention-ai{color:#60a5fa!important}.message-time{font-size:11px;color:var(--text-tertiary);text-align:right}.group-message.own-message .message-time{color:var(--text-tertiary)}.group-message-input-container{position:relative;flex-shrink:0;display:flex;flex-direction:row;align-items:flex-end;padding:12px 12px 8px;background:var(--bg-primary);width:100%;margin:0}.group-message-input{flex:1;margin-right:8px;background:var(--bg-primary);border:1.5px solid #d0d5dd;border-radius:24px;padding:12px 16px;min-height:40px;max-height:120px;display:flex;align-items:flex-end;gap:12px;box-shadow:0 2px 8px #0000000f;transition:all .2s ease}.group-message-input:focus-within{border-color:var(--accent-primary);box-shadow:0 0 0 3px #007bff1a}body.dark-mode .group-message-input{background:#2a2a2a;border-color:#505050;box-shadow:0 2px 8px #0000004d}.message-textarea{flex:1;background:transparent;border:none;outline:none;font-size:16px;line-height:22px;color:var(--text-primary);resize:none;min-height:24px;max-height:120px;padding:8px 0;font-family:inherit}.message-textarea::placeholder{color:var(--text-tertiary)}.send-message-btn{width:36px;height:36px;border-radius:18px;background:var(--border-primary);color:var(--text-secondary);border:none;cursor:pointer;display:flex;align-items:center;justify-content:center;transition:all .2s ease;padding:0;flex-shrink:0}.send-message-btn:not(:disabled){background:var(--accent-primary);color:#fff}.send-message-btn svg{width:20px;height:20px}.send-message-btn:hover:not(:disabled){opacity:.9}.send-message-btn:disabled{opacity:.6;cursor:not-allowed;background:var(--border-primary);color:var(--text-secondary)}.mention-dropdown{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:12px;box-shadow:0 4px 16px #0000001a;overflow:hidden;max-height:200px;overflow-y:auto;z-index:100}.mention-item{display:flex;align-items:center;gap:12px;padding:10px 12px;cursor:pointer;transition:background .2s ease}.mention-item:hover,.mention-item.selected{background:var(--bg-hover)}.mention-avatar{width:32px;height:32px;border-radius:50%;overflow:hidden;flex-shrink:0;background:var(--accent-primary)}.mention-avatar img{width:100%;height:100%;object-fit:cover}.mention-avatar-fallback{width:100%;height:100%;display:flex;align-items:center;justify-content:center;font-size:12px;font-weight:700;color:#fff}.mention-info{flex:1;min-width:0}.mention-name{font-size:14px;font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-email{font-size:12px;color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.mention-admin-badge{padding:2px 8px;background:var(--accent-primary);color:#fff;font-size:10px;font-weight:700;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.mention-invite-badge{padding:2px 8px;background:#10b981;color:#fff;font-size:10px;font-weight:700;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.dark-mode .group-chat-header{background:var(--border-tertiary)}.dark-mode .group-message-list{background:var(--bg-primary)}.dark-mode .group-message:hover{background:#1a1a1a}.dark-mode .message-bubble{background:var(--bg-secondary);border-color:#2a2a2a}.dark-mode .group-message.own-message .message-bubble{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary)}.model-discussion-chat .group-message.own-message .message-bubble{background:linear-gradient(135deg,#047857,#059669);color:#fff;border-color:#047857}.dark-mode .model-discussion-chat .group-message.own-message .message-bubble{background:linear-gradient(135deg,#059669,#10b981);color:#fff;border-color:#059669}.dark-mode .group-message.own-message .message-text{color:#fff}.dark-mode .group-message.own-message .message-time{color:#fffc}.dark-mode .mention-dropdown{background:#1a1a1a;border-color:#2a2a2a;box-shadow:0 4px 16px #00000080}.dark-mode .mention-item:hover,.dark-mode .mention-item.selected{background:#2a2a2a}.group-message.ai-message .message-bubble{background:var(--bg-secondary);border:1px solid var(--border-primary);box-shadow:var(--shadow-sm)}.group-message.ai-message .message-text{color:var(--text-primary)}.ai-sender-name{color:var(--text-tertiary);font-weight:600;display:flex;align-items:center;gap:4px}.ai-requested-by{color:var(--text-secondary);font-weight:400;font-size:12px}.message-avatar-fallback.ai-avatar,.mention-avatar-fallback.ai-avatar{background:var(--bg-secondary);border:1px solid var(--border-primary)}.ai-avatar-logo{width:100%;height:100%;border-radius:50%;object-fit:cover}.ai-thinking-indicator{display:flex;align-items:center;gap:4px;padding:12px 16px;margin:8px 16px}.ai-thinking-indicator span{width:8px;height:8px;border-radius:50%;background:var(--text-secondary);animation:typing 1.4s infinite}.ai-thinking-indicator span:nth-child(2){animation-delay:.2s}.ai-thinking-indicator span:nth-child(3){animation-delay:.4s}@keyframes typing{0%,60%,to{opacity:.3;transform:translateY(0)}30%{opacity:1;transform:translateY(-10px)}}.mention-item.ai-mention{border-left:2px solid var(--accent-primary)}.mention-ai-badge{padding:2px 8px;background:var(--accent-primary);color:#fff;font-size:10px;font-weight:700;border-radius:10px;text-transform:uppercase;letter-spacing:.3px;flex-shrink:0}.competition-toggle-btn{position:absolute;right:16px;top:50%;transform:translateY(-50%);padding:8px;background:transparent;border:1px solid var(--border-secondary);border-radius:8px;cursor:pointer;transition:all .2s ease;color:var(--text-secondary)}.competition-toggle-btn:hover{background:var(--bg-hover);color:var(--accent-primary);border-color:var(--accent-primary)}.competition-toggle-btn-mobile{padding:8px;background:transparent;border:none;cursor:pointer;color:var(--text-secondary);transition:all .2s ease}.competition-toggle-btn-mobile:hover{color:var(--accent-primary)}.competition-leaderboard-container{max-height:300px;overflow-y:auto;border-bottom:1px solid var(--border-secondary);background:var(--bg-secondary);animation:slideDown .3s ease}.members-section-title{font-size:.9rem;font-weight:600;color:#666;margin:1.5rem 0 .75rem;padding-bottom:.5rem;border-bottom:1px solid #e5e5e5;text-transform:uppercase;letter-spacing:.5px}.dark-mode .members-section-title{color:#999;border-bottom-color:#3a3a3a}.members-list .members-section-title:first-child{margin-top:.5rem}.invitations-list{margin-top:2rem;display:flex;flex-direction:column;gap:8px;background:transparent}.invitation-item{display:flex;justify-content:space-between;align-items:center;padding:12px;background:#f8f8f8;border:1px solid #e5e5e5;border-radius:8px;margin-bottom:.5rem;transition:background .2s ease}.invitation-item:hover{background:#f0f0f0}.invitation-info{flex:1}.invitation-email{font-weight:500;color:var(--text-primary);margin-bottom:.25rem}.invitation-date{font-size:.85rem;color:var(--text-secondary)}.invitation-actions{display:flex;gap:.5rem}.btn-secondary-small{padding:.4rem .8rem;font-size:.85rem;background:transparent;color:var(--accent-primary);border:1px solid var(--accent-primary);border-radius:6px;cursor:pointer;transition:all .2s ease}.btn-secondary-small:hover{background:var(--accent-primary);color:#fff}.loading-message{text-align:center;color:var(--text-secondary);padding:1rem;font-style:italic}.dark-mode .invitation-item{background:#2a2a2a;border-color:#3a3a3a}.dark-mode .invitation-item:hover{background:#333}@keyframes slideDown{0%{max-height:0;opacity:0}to{max-height:300px;opacity:1}}body.dark-mode .competition-toggle-btn{border-color:var(--border-secondary-dark);color:var(--text-secondary-dark)}body.dark-mode .competition-toggle-btn:hover{background:var(--bg-hover-dark);border-color:var(--accent-primary)}body.dark-mode .competition-leaderboard-container{background:var(--bg-secondary-dark);border-color:var(--border-secondary-dark)}.competition-details-section{margin-top:2rem;padding:1.5rem;background:linear-gradient(135deg,#ffd7000d,#ffed4e0d);border:1px solid rgba(255,215,0,.3);border-radius:12px}.competition-details-title{font-size:1.1rem;font-weight:700;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.75rem;border-bottom:2px solid rgba(255,215,0,.3)}.competition-detail-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.competition-detail-item{padding:.75rem;background:var(--bg-primary);border-radius:8px;border:1px solid var(--border-color)}.competition-detail-item label{display:block;font-size:.85rem;font-weight:600;color:var(--text-secondary);margin-bottom:.5rem;text-transform:uppercase;letter-spacing:.5px}.competition-detail-value{font-size:1rem;font-weight:600;color:var(--text-primary)}body.dark-mode .competition-details-section{background:linear-gradient(135deg,#ffd70014,#ffed4e14);border-color:#ffd70066}body.dark-mode .competition-details-title{color:var(--text-primary);border-bottom-color:#ffd70066}body.dark-mode .competition-detail-item{background:var(--bg-secondary);border-color:var(--border-color)}body.dark-mode .competition-detail-item label{color:var(--text-secondary)}body.dark-mode .competition-detail-value{color:var(--text-primary)}.message-link-previews{display:flex;flex-direction:column;gap:6px;margin-top:6px;position:relative}.message-link-previews:before{content:"";position:absolute;left:12px;top:-6px;width:2px;height:12px;background:var(--border-primary)}.group-message.own-message .message-link-previews:before{display:none}.link-preview-card{display:flex;gap:12px;padding:12px;background:var(--bg-secondary);border:1px solid var(--border-primary);border-radius:4px 12px 12px;text-decoration:none;color:inherit;transition:all .2s ease;overflow:hidden;max-width:500px;cursor:pointer;position:relative}.link-preview-card:before{content:"";position:absolute;left:0;top:0;width:3px;height:100%;background:var(--accent-primary);opacity:.3;transition:opacity .2s ease}.link-preview-card:hover:before{opacity:.6}.group-message.own-message .link-preview-card{border-top-right-radius:4px;border-top-left-radius:12px;background:#2563eb14;border-color:#2563eb33}.group-message.own-message .link-preview-card:before{left:auto;right:0;background:#fff;opacity:.4}.group-message.own-message .link-preview-card:hover{background:#2563eb1f;border-color:var(--accent-primary)}.dark-mode .group-message.own-message .link-preview-card{background:#2563eb26;border-color:#2563eb4d}.dark-mode .group-message.own-message .link-preview-card:hover{background:#2563eb33}.link-preview-card:hover{background:var(--bg-hover);border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:0 4px 12px #0000001a}.dark-mode .link-preview-card:hover{box-shadow:0 4px 12px #0000004d}.link-preview-card.loading{pointer-events:none}.link-preview-image{flex-shrink:0;width:80px;height:80px;border-radius:8px;overflow:hidden;background:var(--bg-tertiary);display:flex;align-items:center;justify-content:center}.link-preview-image img{width:100%;height:100%;object-fit:cover}.link-preview-image.skeleton{background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite}.link-preview-content{flex:1;min-width:0;display:flex;flex-direction:column;gap:6px}.link-preview-header{display:flex;align-items:flex-start;gap:8px}.link-preview-title{margin:0;font-size:14px;font-weight:600;color:var(--text-primary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;flex:1}.link-preview-badge{flex-shrink:0;padding:2px 6px;background:#2563eb1a;color:var(--accent-primary);font-size:10px;font-weight:600;border-radius:4px;text-transform:uppercase;letter-spacing:.3px}.dark-mode .link-preview-badge{background:#2563eb33;color:#60a5fa}.link-preview-description{margin:0;font-size:13px;color:var(--text-secondary);line-height:1.4;overflow:hidden;text-overflow:ellipsis;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical}.link-preview-stats{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.link-preview-stat{display:flex;align-items:center;gap:4px;font-size:12px;color:var(--text-tertiary)}.link-preview-stat svg{flex-shrink:0;opacity:.7}.skeleton-text{height:14px;background:linear-gradient(90deg,var(--bg-tertiary) 25%,var(--bg-hover) 50%,var(--bg-tertiary) 75%);background-size:200% 100%;animation:skeleton-loading 1.5s infinite;border-radius:4px;margin-bottom:6px}.skeleton-text.short{width:60%}@keyframes skeleton-loading{0%{background-position:200% 0}to{background-position:-200% 0}}@media (max-width: 600px){.link-preview-card{max-width:100%}.link-preview-image{width:60px;height:60px}.link-preview-title{font-size:13px}.link-preview-description{font-size:12px}.link-preview-stats{gap:8px}.link-preview-stat{font-size:11px}}.pinned-model-section{padding:0;background:var(--bg-primary);flex-shrink:0;margin-bottom:8px}.dark-mode .pinned-model-section{background:var(--bg-primary);border-color:var(--border-primary)}.pinned-model-section .link-preview-card{cursor:pointer;transition:all .2s ease}.pinned-model-section .link-preview-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a;border-color:var(--accent-primary)}.pinned-model-section .model-card-mini{max-width:600px}.pinned-model-banner{display:flex;align-items:center;gap:6px;margin-bottom:0;padding:6px 12px;background:linear-gradient(135deg,#05966914,#10b98114);border:0px solid rgba(5,150,105,.2);border-radius:6px;font-size:11px;font-weight:600;color:#047857}.pinned-model-banner svg{flex-shrink:0;opacity:.7}.dark-mode .pinned-model-banner{background:linear-gradient(135deg,#10b9811f,#0596691f);border-color:#10b98140;color:#10b981}.group-messages-wrapper{flex:1;overflow-y:auto;padding:0 16px 16px;scrollbar-width:none;-ms-overflow-style:none}.group-messages-wrapper::-webkit-scrollbar{display:none}.creator-badge{color:var(--accent-primary, #2563eb);font-size:.9em;font-weight:500;margin-left:4px}.message-sender-name .creator-badge{display:inline;font-style:normal}.stat-item.activity-indicator{color:var(--accent-primary, #2563eb);font-weight:600}.stat-item.activity-indicator svg{stroke:var(--accent-primary, #2563eb)}@media (max-width: 768px){.pinned-model-section{padding:12px}}.quick-actions-container{padding:16px;margin-bottom:20px}.quick-actions-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:16px}.quick-actions-chatgpt{display:flex;flex-direction:column;gap:2px;margin-top:8px;max-width:700px;margin-left:auto;margin-right:auto;width:100%;padding:0 20px}.quick-actions-chatgpt-wrapper{padding:0!important;width:80%;max-width:700px;margin:0 auto!important}.chat-input-container.centered+.quick-actions-chatgpt-wrapper,.chat-centered-container.centered+.quick-actions-chatgpt-wrapper{position:absolute;top:calc(33% + 60px);left:50%;transform:translate(-50%);width:80%;max-width:700px;padding:0!important;margin:0!important}.quick-actions-chatgpt .quick-action-card{display:flex;flex-direction:row;align-items:center;padding:6px 12px;background-color:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease;min-height:auto;box-shadow:none;gap:10px}.quick-actions-chatgpt .quick-action-card:hover{background-color:var(--bg-secondary, #f3f4f6);border:none;box-shadow:none;transform:none}.quick-actions-chatgpt .quick-action-icon-container{width:auto;height:auto;border-radius:0;margin-right:0;background-color:transparent;display:flex;align-items:center;justify-content:center}.quick-actions-chatgpt .quick-action-icon{font-size:20px}.quick-actions-chatgpt .quick-action-content{display:flex;flex-direction:row;align-items:baseline;gap:8px;flex:1}.quick-actions-chatgpt .quick-action-title{font-size:14px;font-weight:600;margin:0;white-space:nowrap}.quick-actions-chatgpt .quick-action-subtitle{font-size:13px;font-weight:400;color:var(--text-tertiary, #9ca3af);margin:0;opacity:.8}.quick-actions-chatgpt .quick-action-chevron{font-size:16px;color:var(--text-tertiary, #9ca3af);margin-left:0}body.dark-mode .quick-actions-chatgpt .quick-action-card{background-color:transparent;border:none}body.dark-mode .quick-actions-chatgpt .quick-action-card:hover{background-color:var(--bg-secondary, #2a2a2a);border:none}.quick-actions-compact{display:flex;flex-wrap:wrap;gap:8px;justify-content:center}.quick-actions-popup-wrapper{position:absolute;bottom:calc(100% + 8px);left:0;z-index:1000;animation:slideUpFadeIn .2s ease-out}@keyframes slideUpFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.quick-actions-popup{display:flex;flex-direction:column;gap:2px;min-width:280px;max-width:320px;max-height:400px;overflow-y:auto;background-color:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;box-shadow:0 4px 20px #00000026;padding:6px}body.dark-mode .quick-actions-popup{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);box-shadow:0 4px 20px #0006}.quick-actions-popup .quick-action-card{display:flex;flex-direction:row;align-items:center;padding:10px 12px;background-color:transparent;border:none;border-radius:8px;cursor:pointer;transition:all .15s ease;min-height:auto;box-shadow:none;gap:10px}.quick-actions-popup .quick-action-card:hover{background-color:var(--bg-secondary, #f3f4f6);border:none;box-shadow:none;transform:none}body.dark-mode .quick-actions-popup .quick-action-card:hover{background-color:var(--bg-hover-dark, #3a3a3a)}.quick-actions-popup .quick-action-icon-container{width:auto;height:auto;border-radius:0;margin-right:0;background-color:transparent;display:flex;align-items:center;justify-content:center}.quick-actions-popup .quick-action-icon{font-size:20px}.quick-actions-popup .quick-action-content{display:flex;flex-direction:column;align-items:flex-start;gap:2px;flex:1}.quick-actions-popup .quick-action-title{font-size:14px;font-weight:600;margin:0}.quick-actions-popup .quick-action-subtitle{font-size:12px;font-weight:400;color:var(--text-tertiary, #9ca3af);margin:0;opacity:.8}.quick-actions-popup .quick-action-chevron{font-size:16px;color:var(--text-tertiary, #9ca3af);margin-left:0}.quick-actions-compact .quick-action-card{display:inline-flex;align-items:center;padding:8px 16px;border-radius:20px;min-height:auto;gap:8px}.quick-actions-compact .quick-action-icon-container{width:24px;height:24px;margin-right:0}.quick-actions-compact .quick-action-icon{font-size:16px}.quick-actions-compact .quick-action-subtitle,.quick-actions-compact .quick-action-chevron{display:none}@media (max-width: 1024px){.quick-actions-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.quick-actions-grid{grid-template-columns:1fr}}.quick-action-card{display:flex;align-items:center;padding:16px;background-color:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;cursor:pointer;transition:all .2s ease;min-height:80px;box-shadow:0 1px 3px #0000000d}.quick-action-card:hover{background-color:var(--bg-hover, #f3f4f6);border-color:var(--primary-color, #3b82f6);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.quick-action-card:active{transform:translateY(0)}body.dark-mode .quick-action-card{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);box-shadow:0 1px 3px #0003}body.dark-mode .quick-action-card:hover{background-color:var(--bg-hover-dark, #3a3a3a);border-color:var(--primary-color, #3b82f6);box-shadow:0 4px 12px #0000004d}.quick-action-icon-container{width:48px;height:48px;border-radius:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:12px}.quick-action-icon{font-size:24px}.quick-action-content{flex:1;min-width:0}.quick-action-title{font-size:16px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 4px}body.dark-mode .quick-action-title{color:var(--text-primary-dark, #f9fafb)}.quick-action-subtitle{font-size:13px;color:var(--text-secondary, #6b7280);margin:0}body.dark-mode .quick-action-subtitle{color:var(--text-secondary-dark, #9ca3af)}.quick-action-chevron{font-size:20px;color:var(--text-secondary, #9ca3af);margin-left:8px;flex-shrink:0}body.dark-mode .quick-action-chevron{color:var(--text-secondary-dark, #6b7280)}.expandable-component-card{display:flex;align-items:center;padding:16px;background-color:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;cursor:pointer;transition:all .2s ease;min-height:80px;box-shadow:0 1px 3px #0000000d;margin:8px 0}.expandable-component-card:hover{background-color:var(--bg-hover, #f3f4f6);border-color:var(--primary-color, #3b82f6);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}body.dark-mode .expandable-component-card{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}body.dark-mode .expandable-component-card:hover{background-color:var(--bg-hover-dark, #3a3a3a);border-color:var(--primary-color, #3b82f6)}.expandable-component-icon{width:48px;height:48px;border-radius:24px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:12px;font-size:24px}.expandable-component-content{flex:1;min-width:0}.expandable-component-title{font-size:16px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 4px}body.dark-mode .expandable-component-title{color:var(--text-primary-dark, #f9fafb)}.expandable-component-subtitle{font-size:13px;color:var(--text-secondary, #6b7280);margin:0}body.dark-mode .expandable-component-subtitle{color:var(--text-secondary-dark, #9ca3af)}.expandable-component-chevron{font-size:20px;color:var(--text-secondary, #9ca3af);margin-left:8px;flex-shrink:0}body.dark-mode .expandable-component-chevron{color:var(--text-secondary-dark, #6b7280)}@media (max-width: 768px){.quick-actions-container{padding:12px}.quick-action-card{padding:14px;min-height:70px}.quick-action-icon-container{width:40px;height:40px;border-radius:20px}.quick-action-icon{font-size:20px}.quick-action-title{font-size:15px}.quick-action-subtitle{font-size:12px}.expandable-component-card{padding:14px;min-height:70px}.expandable-component-icon{width:40px;height:40px;font-size:20px}.chat-input-container.centered+.quick-actions-chatgpt-wrapper,.chat-centered-container.centered+.quick-actions-chatgpt-wrapper,.mobile-chat-input-bar.centered+.quick-actions-chatgpt-wrapper{position:absolute!important;top:calc(30% + 60px)!important;left:50%!important;transform:translate(-50%)!important;width:90%!important;max-width:100%!important;padding:0!important;margin:0!important;bottom:auto!important}.quick-actions-chatgpt{padding:0 12px}}.navigation-card{display:flex;align-items:center;padding:12px 16px;background-color:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;cursor:pointer;transition:all .2s ease;margin:6px 0}.navigation-card:hover{background-color:var(--bg-hover, #f3f4f6);border-color:var(--primary-color, #3b82f6);box-shadow:0 2px 8px #00000014;transform:translate(4px)}body.dark-mode .navigation-card{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}body.dark-mode .navigation-card:hover{background-color:var(--bg-hover-dark, #3a3a3a);border-color:var(--primary-color, #3b82f6);box-shadow:0 2px 8px #0003}.navigation-icon-container{width:32px;height:32px;border-radius:16px;display:flex;align-items:center;justify-content:center;flex-shrink:0;margin-right:12px}.navigation-icon{font-size:18px}.navigation-label{flex:1;font-size:15px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .navigation-label{color:var(--text-primary-dark, #f9fafb)}.navigation-chevron{font-size:18px;color:var(--text-secondary, #9ca3af);flex-shrink:0}body.dark-mode .navigation-chevron{color:var(--text-secondary-dark, #6b7280)}@media (max-width: 768px){.navigation-card{padding:10px 14px}.navigation-icon-container{width:28px;height:28px;border-radius:14px}.navigation-icon{font-size:16px}.navigation-label{font-size:14px}}.model-card{position:relative;padding:16px;background-color:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;cursor:pointer;transition:all .2s ease;box-shadow:0 2px 4px #0000000d}.model-card:hover{background-color:var(--bg-hover, #f3f4f6);border-color:var(--primary-color, #3b82f6);box-shadow:0 4px 12px #00000014;transform:translateY(-2px)}.model-card-wrapper.selected .model-card{border-color:var(--primary, #3b82f6);box-shadow:0 0 0 2px #3b82f633;background:#3b82f60d}body.dark-mode .model-card{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);box-shadow:0 2px 4px #0003}body.dark-mode .model-card:hover{background-color:var(--bg-hover-dark, #3a3a3a);border-color:var(--primary-color, #3b82f6);box-shadow:0 4px 12px #0000004d}body.dark-mode .model-card-wrapper.selected .model-card{border-color:var(--primary, #3b82f6);box-shadow:0 0 0 2px #3b82f64d;background:#3b82f61a}.model-card-header{display:flex;justify-content:space-between;align-items:flex-start;margin-bottom:8px;gap:8px}.model-menu-container{position:relative;display:flex;align-items:center}.model-menu-button{width:24px;height:24px;display:flex;align-items:center;justify-content:center;background:transparent;border:none;border-radius:4px;cursor:pointer;font-size:18px;color:var(--text-secondary, #6b7280);transition:all .2s ease;padding:0}.model-menu-button:hover{background-color:var(--bg-hover, #f3f4f6);color:var(--text-primary, #111827)}body.dark-mode .model-menu-button{color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .model-menu-button:hover{background-color:var(--bg-hover-dark, #3a3a3a);color:var(--text-primary-dark, #f9fafb)}.model-menu-dropdown{position:absolute;top:28px;left:0;z-index:1000;background-color:var(--bg-primary, #ffffff);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;box-shadow:0 4px 12px #0000001a;overflow:hidden;min-width:140px;animation:menuFadeIn .15s ease}body.dark-mode .model-menu-dropdown{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);box-shadow:0 4px 12px #0006}@keyframes menuFadeIn{0%{opacity:0;transform:translateY(-4px)}to{opacity:1;transform:translateY(0)}}.model-menu-dropdown .menu-item{display:flex;align-items:center;gap:8px;width:100%;padding:10px 14px;background:transparent;border:none;text-align:left;font-size:14px;color:var(--text-primary, #111827);cursor:pointer;transition:background-color .15s ease}.model-menu-dropdown .menu-item:hover{background-color:var(--bg-hover, #f3f4f6)}body.dark-mode .model-menu-dropdown .menu-item{color:var(--text-primary-dark, #f9fafb)}body.dark-mode .model-menu-dropdown .menu-item:hover{background-color:var(--bg-hover-dark, #3a3a3a)}.model-menu-dropdown .menu-item-danger{color:#dc2626}.model-menu-dropdown .menu-item-danger:hover{background-color:#dc26261a}body.dark-mode .model-menu-dropdown .menu-item-danger{color:#ef4444}body.dark-mode .model-menu-dropdown .menu-item-danger:hover{background-color:#ef444426}.model-card-name-container{flex:1;margin-right:12px}.model-card-name{font-size:18px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 8px;line-height:1.3}body.dark-mode .model-card-name{color:var(--text-primary-dark, #f9fafb)}.model-card-badges{display:flex;gap:8px;align-items:center}.model-badge{display:inline-flex;align-items:center;gap:4px;padding:4px 10px;border-radius:12px;font-size:11px;font-weight:600}.model-badge.ai{background-color:#e9d5ff;color:#6b21a8}body.dark-mode .model-badge.ai{background-color:#581c87;color:#e9d5ff}.model-badge.remodeled{background-color:#dbeafe;color:#1e40af}body.dark-mode .model-badge.remodeled{background-color:#1e3a8a;color:#dbeafe}.badge-icon{font-size:12px}.badge-text{font-size:11px;font-weight:600}.model-conversation-icon{padding:4px 8px;background:transparent;border:1px solid var(--border-color, #d1d5db);border-radius:6px;cursor:pointer;font-size:14px;transition:all .2s ease;display:inline-flex;align-items:center;justify-content:center}.model-conversation-icon:hover{background-color:var(--bg-hover, #f3f4f6);border-color:var(--primary-color, #3b82f6)}body.dark-mode .model-conversation-icon{border-color:var(--border-color-dark, #444)}body.dark-mode .model-conversation-icon:hover{background-color:var(--bg-hover-dark, #3a3a3a);border-color:var(--primary-color, #3b82f6)}.model-card-chevron{font-size:20px;color:var(--text-secondary, #9ca3af);opacity:0;transition:opacity .2s ease;margin-top:2px}.model-card:hover .model-card-chevron{opacity:1}body.dark-mode .model-card-chevron{color:var(--text-secondary-dark, #6b7280)}.model-info-row{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;gap:8px}.model-holdings-count{font-size:13px;color:var(--text-secondary, #6b7280);margin:0}body.dark-mode .model-holdings-count{color:var(--text-secondary-dark, #9ca3af)}.model-timeframe-label{font-size:12px;color:var(--text-secondary, #6b7280);font-style:italic;margin:0;white-space:nowrap}body.dark-mode .model-timeframe-label{color:var(--text-secondary-dark, #9ca3af)}.model-visibility-toggle-container{display:flex;justify-content:flex-end;padding:8px 0 4px}.model-visibility-toggle{background:transparent;border:none;cursor:pointer;font-size:16px;padding:4px 8px;border-radius:6px;transition:background-color .2s ease;line-height:1}.model-visibility-toggle:hover{background-color:var(--bg-hover, #f3f4f6)}body.dark-mode .model-visibility-toggle:hover{background-color:var(--bg-hover-dark, #3a3a3a)}.model-metrics-container{display:flex;justify-content:space-around;align-items:center;padding-top:12px;border-top:1px solid rgba(128,128,128,.2);gap:8px}body.dark-mode .model-metrics-container{border-top-color:#ffffff1a}.model-metric{flex:1;display:flex;flex-direction:column;align-items:center;gap:4px}.metric-label{font-size:11px;color:var(--text-secondary, #6b7280);font-weight:500}.metric-value{font-size:16px;font-weight:700}.metric-value.positive{color:#059669}.metric-value.negative{color:#dc2626}.metric-value.neutral{color:var(--text-primary, #111827)}body.dark-mode .metric-value.positive{color:#10b981}body.dark-mode .metric-value.negative{color:#ef4444}body.dark-mode .metric-value.neutral{color:var(--text-primary-dark, #f9fafb)}.metric-value-stacked{display:flex;flex-direction:column;align-items:center;gap:2px}.metric-sub-value{font-size:11px;font-weight:500;opacity:.8}.metric-sub-value.positive{color:#059669}.metric-sub-value.negative{color:#dc2626}.metric-sub-value.neutral{color:var(--text-secondary, #6b7280)}body.dark-mode .metric-sub-value.positive{color:#10b981}body.dark-mode .metric-sub-value.negative{color:#ef4444}body.dark-mode .metric-sub-value.neutral{color:var(--text-secondary-dark, #9ca3af)}.metric-divider{width:1px;height:40px;background-color:#80808033;margin:0 4px}body.dark-mode .metric-divider{background-color:#ffffff1a}.model-metrics-loading{display:flex;align-items:center;justify-content:center;padding:16px;gap:12px}.spinner{width:20px;height:20px;border:2px solid var(--border-color, #e5e7eb);border-top-color:var(--primary-color, #3b82f6);border-radius:50%;animation:spin .8s linear infinite}body.dark-mode .spinner{border-color:var(--border-color-dark, #444);border-top-color:var(--primary-color, #3b82f6)}.loading-text{font-size:13px;color:var(--text-secondary, #6b7280)}body.dark-mode .loading-text{color:var(--text-secondary-dark, #9ca3af)}.model-metrics-error{display:flex;align-items:center;justify-content:center;padding:16px}.error-text{font-size:13px;color:#dc2626}body.dark-mode .error-text{color:#ef4444}@media (max-width: 768px){.model-card{padding:14px}.model-card-name{font-size:16px}.model-card-chevron{opacity:1}.model-metrics-container{padding-top:10px}.metric-value{font-size:15px}.metric-label{font-size:10px}.metric-divider{height:35px}}.model-list-card{padding:16px 0}.model-list-header{font-size:20px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 16px;padding:0 16px}body.dark-mode .model-list-header{color:var(--text-primary-dark, #f9fafb)}.model-list-container{padding:0 16px;max-height:600px;overflow-y:auto;display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:12px}.model-list-container::-webkit-scrollbar{width:6px}.model-list-container::-webkit-scrollbar-track{background:transparent}.model-list-container::-webkit-scrollbar-thumb{background:var(--border-color, #d1d5db);border-radius:3px}.model-list-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary, #9ca3af)}body.dark-mode .model-list-container::-webkit-scrollbar-thumb{background:var(--border-color-dark, #444)}body.dark-mode .model-list-container::-webkit-scrollbar-thumb:hover{background:var(--text-secondary-dark, #6b7280)}.model-list-empty{padding:32px 16px;text-align:center}.empty-message{font-size:15px;color:var(--text-secondary, #6b7280);margin:0}body.dark-mode .empty-message{color:var(--text-secondary-dark, #9ca3af)}@media (max-width: 768px){.model-list-card{padding:12px 0}.model-list-header{font-size:18px;margin:0 0 12px;padding:0 12px}.model-list-container{padding:0 12px;max-height:500px}.model-list-empty{padding:24px 12px}}.model-detail-card-inline{padding:20px;background-color:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;margin:12px 0}body.dark-mode .model-detail-card-inline{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.model-detail-inline-header{margin-bottom:16px}.model-detail-inline-title{display:flex;flex-direction:column;gap:8px}.model-detail-inline-title h3{font-size:20px;font-weight:600;color:var(--text-primary, #111827);margin:0}body.dark-mode .model-detail-inline-title h3{color:var(--text-primary-dark, #f9fafb)}.model-inline-badges{display:flex;gap:8px}.model-inline-badge{padding:4px 12px;border-radius:12px;font-size:11px;font-weight:600;display:inline-block}.model-inline-badge.ai{background-color:#e9d5ff;color:#6b21a8}body.dark-mode .model-inline-badge.ai{background-color:#581c87;color:#e9d5ff}.model-inline-badge.remodeled{background-color:#fef3c7;color:#92400e}body.dark-mode .model-inline-badge.remodeled{background-color:#78350f;color:#fef3c7}.model-detail-inline-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:16px;margin-bottom:16px}.summary-stat{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.5px}.model-expand-btn{width:100%;padding:12px;background-color:var(--primary-color, #3b82f6);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.model-expand-btn:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.model-expand-btn:active{transform:translateY(0)}@media (max-width: 768px){.model-detail-card-inline{padding:16px}.model-detail-inline-title h3{font-size:18px}.model-detail-inline-summary{grid-template-columns:1fr;gap:12px}}.model-detail-expanded{display:flex;flex-direction:column;gap:20px;padding:20px;width:100%;max-width:100%;height:100vh;overflow-y:auto;overflow-x:hidden;scrollbar-width:none;-ms-overflow-style:none}.model-detail-expanded::-webkit-scrollbar{display:none}.model-expanded-header{background:var(--bg-secondary);border-radius:12px;padding:24px}.model-expanded-title-section{display:flex;flex-direction:column;gap:12px}.model-expanded-title{font-size:28px;font-weight:700;color:var(--text-primary);margin:0;line-height:1.2}body.dark-mode .model-expanded-title{color:var(--text-primary-dark)}.model-expanded-badge-row{display:flex;align-items:center;gap:12px;flex-wrap:wrap}.model-expanded-badge{display:inline-flex;align-items:center;gap:6px;padding:6px 12px;border-radius:8px;font-size:13px;font-weight:600}.model-expanded-badge.ai.generated,.model-expanded-badge.ai{background-color:#3b82f626;color:#2563eb}body.dark-mode .model-expanded-badge.ai.generated,body.dark-mode .model-expanded-badge.ai{background-color:#3b82f633;color:#60a5fa}.model-expanded-badge.remodeled{background-color:#ffc10726;color:#f57c00}body.dark-mode .model-expanded-badge.remodeled{background-color:#ffc10733;color:#ffa726}.badge-icon{font-size:14px}.badge-text{font-size:12px}.view-chat-btn{display:inline-flex;align-items:center;gap:4px;padding:6px 12px;border:none;background:none;color:var(--primary-color);font-size:12px;font-weight:600;cursor:pointer;border-radius:6px;transition:background-color .2s}.view-chat-btn:hover{background-color:var(--hover-background)}.remodel-warning-banner{display:flex;align-items:center;gap:8px;padding:12px 16px;background-color:#ffc10726;border:1px solid rgba(255,193,7,.3);border-radius:8px;color:#f57c00}body.dark-mode .remodel-warning-banner{background-color:#ffc10733;border-color:#ffc10766;color:#ffa726}.warning-icon{font-size:16px}.warning-text{font-size:13px;font-weight:600}.model-date-row{display:flex;align-items:center;gap:8px;font-size:13px;color:var(--text-secondary)}body.dark-mode .model-date-row{color:var(--text-secondary-dark)}.date-label{font-weight:600}.date-value{font-weight:400}.model-expanded-section{background:var(--bg-primary);border-radius:12px;padding:16px}.section-content{margin-top:12px}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;-webkit-user-select:none;user-select:none}.section-header.clickable{cursor:pointer;transition:background-color .2s;margin:-4px -4px 0;padding:8px;border-radius:8px}.section-header.clickable:hover{background-color:var(--hover-background)}.section-header-content{display:flex;align-items:center;gap:10px}.section-header-controls{display:flex;align-items:center;gap:12px}.section-header-controls .benchmark-selector{padding:10px 16px;border:1px solid var(--border-color);border-radius:10px;background:var(--background-primary);color:var(--text-primary);font-size:14px;font-weight:500;cursor:pointer;transition:border-color .2s;min-width:200px;text-align:left}.section-header-controls .benchmark-selector:hover{border-color:var(--primary-color)}.section-header-controls .benchmark-selector:focus{outline:none;border-color:var(--primary-color);box-shadow:0 0 0 3px #3b82f61a}.section-icon{font-size:18px}.section-title{font-size:18px;font-weight:600;color:var(--text-primary);margin:0}body.dark-mode .section-title{color:var(--text-primary-dark)}.holdings-separator{margin:40px 0 24px;padding-top:32px;border-top:2px solid var(--border-color)}.holdings-header-row{display:flex;align-items:center;gap:12px;margin-bottom:16px}.holdings-subtitle{font-size:16px;font-weight:600;color:var(--text-primary);margin:0}.holdings-edit-btn{background:transparent;border:none;font-size:16px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;border-radius:4px;transition:all .2s;opacity:.6;line-height:1;display:flex;align-items:center;justify-content:center}.holdings-edit-btn:hover:not(:disabled){background:var(--hover-background);opacity:1;color:var(--primary-color)}.holdings-edit-btn:disabled{opacity:.3;cursor:not-allowed}body.dark-mode .holdings-edit-btn{color:var(--text-secondary-dark)}body.dark-mode .holdings-edit-btn:hover:not(:disabled){color:var(--primary-color)}.model-action-icons{display:flex;justify-content:flex-end;align-items:center;gap:8px;margin-bottom:16px}.model-icon-btn{background:transparent;border:none;font-size:20px;cursor:pointer;padding:8px;border-radius:6px;transition:all .2s;opacity:.6;line-height:1;display:flex;align-items:center;justify-content:center;min-width:36px;min-height:36px}.model-icon-btn:hover:not(:disabled){opacity:1;background:var(--hover-background)}.model-icon-btn:disabled{opacity:.3;cursor:not-allowed}.share-icon-btn:hover:not(:disabled){background:#3b82f61a}.delete-icon-btn:hover:not(:disabled){background:#ef44441a}body.dark-mode .share-icon-btn:hover:not(:disabled){background:#3b82f633}body.dark-mode .delete-icon-btn:hover:not(:disabled){background:#ef444433}.section-toggle-btn{background:none;border:none;font-size:14px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;transition:color .2s;line-height:1}body.dark-mode .section-toggle-btn{color:var(--text-secondary-dark)}.section-toggle-btn:hover{color:var(--text-primary)}body.dark-mode .section-toggle-btn:hover{color:var(--text-primary-dark)}.model-expanded-actions{background:var(--bg-secondary);border-radius:12px;padding:20px;margin-top:8px}.action-buttons-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(140px,1fr));gap:12px}.model-action-btn{display:flex;align-items:center;justify-content:center;gap:8px;padding:14px 20px;border-radius:10px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;border:none;white-space:nowrap}.model-action-btn.primary{background-color:var(--primary-color);color:#fff;border:none}.model-action-btn.primary:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #00000026}.model-action-btn.secondary{background-color:transparent;color:var(--text-primary);border:1.5px solid var(--border-color)}body.dark-mode .model-action-btn.secondary{color:var(--text-primary-dark);border-color:var(--border-color-dark)}.model-action-btn.secondary:hover{background-color:var(--hover-background);border-color:var(--primary-color);color:var(--primary-color)}.model-action-btn.danger{background-color:transparent;color:#dc2626;border:1.5px solid #dc2626}.model-action-btn.danger:hover{background-color:#f443361a;border-color:#dc2626}body.dark-mode .model-action-btn.danger{color:#fca5a5;border-color:#991b1b}body.dark-mode .model-action-btn.danger:hover{background-color:#7f1d1d;border-color:#fca5a5}.model-action-btn:disabled{opacity:.5;cursor:not-allowed}.model-action-btn:disabled:hover{transform:none;box-shadow:none}.delete-confirmation-modal{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#00000080;display:flex;align-items:center;justify-content:center;z-index:1000;padding:16px}.delete-modal-content{background:var(--background-primary);border-radius:16px;max-width:500px;width:100%;box-shadow:0 20px 60px #0000004d}.delete-modal-header{display:flex;justify-content:space-between;align-items:center;padding:20px 24px;border-bottom:1px solid var(--border-color)}.delete-modal-header h3{margin:0;font-size:18px;font-weight:700;color:var(--text-primary)}.modal-close-btn{background:none;border:none;font-size:24px;color:var(--text-secondary);cursor:pointer;padding:4px;line-height:1;min-width:32px;min-height:32px;display:flex;align-items:center;justify-content:center}.modal-close-btn:hover{color:var(--text-primary)}.delete-modal-body{padding:24px}.delete-warning-text{font-size:15px;color:var(--text-primary);margin:0 0 16px}.delete-warning-box{background:#ffc1071a;border:1px solid rgba(255,193,7,.3);border-radius:8px;padding:16px;display:flex;gap:12px;margin-bottom:16px}.delete-warning-box .warning-icon{font-size:24px;flex-shrink:0}.delete-warning-box .warning-details{flex:1}.delete-warning-box p{margin:0 0 8px;font-size:14px;color:var(--text-primary)}.delete-warning-box ul{margin:8px 0;padding-left:20px;font-size:14px;color:var(--text-primary)}.warning-emphasis{font-weight:600;color:#f57c00}.delete-error-box{background:#dc26261a;border:1px solid rgba(220,38,38,.3);border-radius:8px;padding:12px;display:flex;gap:8px;align-items:center;color:#dc2626;font-size:14px}.delete-modal-actions{display:flex;gap:12px;padding:20px 24px;border-top:1px solid var(--border-color)}.cancel-btn,.confirm-delete-btn{flex:1;padding:12px 24px;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s;min-height:44px}.cancel-btn{background:transparent;border:1.5px solid var(--border-color);color:var(--text-primary)}.cancel-btn:hover{background:var(--hover-background);border-color:var(--primary-color)}.confirm-delete-btn{background:#dc2626;border:none;color:#fff}.confirm-delete-btn:hover{background:#b91c1c}.confirm-delete-btn:disabled,.cancel-btn:disabled{opacity:.5;cursor:not-allowed}@media (max-width: 768px){.model-detail-expanded{padding:12px;gap:16px}.model-expanded-title{font-size:22px}.model-expanded-header{padding:16px}.model-expanded-section{padding:8px 6px}.section-header{flex-direction:column;align-items:flex-start;gap:12px}.section-header-controls{width:100%}.section-header-controls .benchmark-selector{width:100%;min-width:unset}.holdings-separator{margin:24px 0 16px;padding-top:20px}.action-buttons-grid{grid-template-columns:1fr}.model-action-btn{width:100%;min-height:48px}.view-chat-btn{min-height:32px;padding:8px 12px}}@media (max-width: 480px){.model-detail-expanded{padding:8px}.model-expanded-title{font-size:20px}.model-expanded-header,.model-expanded-section,.model-expanded-actions{padding:8px 4px}.section-title{font-size:16px}.model-expanded-badge{font-size:12px;padding:4px 10px}.delete-modal-content{margin:0;border-radius:12px}.delete-modal-header,.delete-modal-body,.delete-modal-actions{padding:16px}.delete-modal-actions{flex-direction:column}.cancel-btn,.confirm-delete-btn{width:100%}}.empty-model-state{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 24px;text-align:center;background:var(--bg-secondary);border-radius:12px;border:2px dashed var(--border-color)}body.dark-mode .empty-model-state{background:var(--bg-secondary-dark);border-color:var(--border-color-dark)}.empty-state-icon{font-size:64px;margin:0 0 16px;opacity:.5}.empty-state-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}body.dark-mode .empty-state-title{color:var(--text-primary-dark)}.empty-state-description{font-size:15px;color:var(--text-secondary);line-height:1.6;max-width:500px;margin:0}body.dark-mode .empty-state-description{color:var(--text-secondary-dark)}@media (max-width: 768px){.empty-model-state{padding:40px 20px}.empty-state-icon{font-size:48px}.empty-state-title{font-size:18px}.empty-state-description{font-size:14px}}.commentary-section{margin:16px 0}.commentary-label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-primary);font-size:14px}.commentary-description{font-size:14px;color:var(--text-secondary);margin-bottom:12px;line-height:1.5}.commentary-textarea{width:100%;padding:12px;border:1px solid var(--border-color);border-radius:8px;font-size:14px;font-family:inherit;resize:vertical;min-height:100px;background:var(--background-primary);color:var(--text-primary);transition:border-color .2s}.commentary-textarea:focus{outline:none;border-color:var(--primary-color)}.commentary-textarea:disabled{opacity:.6;cursor:not-allowed}.character-count{font-size:12px;color:var(--text-tertiary);margin-top:8px;text-align:right}.share-success-container{text-align:center;padding:20px 0}.success-icon-large{font-size:48px;margin-bottom:16px}.success-title{margin-bottom:8px;font-size:18px;font-weight:600;color:var(--text-primary)}.success-description{color:var(--text-secondary);margin-bottom:24px;font-size:14px}.share-url-container{display:flex;gap:8px;margin-bottom:16px;padding:12px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color)}.share-url-input{flex:1;padding:8px;border:none;background:transparent;font-size:14px;font-family:monospace;color:var(--text-primary)}.share-url-input:focus{outline:none}.copy-link-btn{padding:8px 16px;background:var(--primary-color);color:#fff;border:none;border-radius:6px;cursor:pointer;font-size:14px;font-weight:500;transition:background .2s;white-space:nowrap}.copy-link-btn:hover{background:var(--accent-hover)}.copy-link-btn.copied{background:var(--success-color)}.model-detail-expanded.public-model.model-action-btn.primary{background:linear-gradient(135deg,#047857,#059669);border-color:#047857}.model-detail-expanded.public-model.model-action-btn.primary:hover{background:linear-gradient(135deg,#036149,#047857);border-color:#036149}.model-detail-expanded.public-model.investment-save-btn{background:linear-gradient(135deg,#047857,#059669);border-color:#047857}.model-detail-expanded.public-model.investment-save-btn:hover{background:linear-gradient(135deg,#036149,#047857)}.model-detail-expanded.public-model.holdings-edit-btn{color:#047857;border-color:#0478574d}.model-detail-expanded.public-model.holdings-edit-btn:hover{background:#0478571a;border-color:#047857}.model-detail-expanded.public-model.section-icon{filter:hue-rotate(160deg)}.model-detail-expanded.public-model.mini-metric-value.positive,.model-detail-expanded.public-model.sparkline-path.positive{color:#047857;stroke:#047857}body.dark-mode .model-detail-expanded.public-model.model-action-btn.primary{background:linear-gradient(135deg,#059669,#10b981);border-color:#059669}body.dark-mode .model-detail-expanded.public-model.model-action-btn.primary:hover{background:linear-gradient(135deg,#047857,#059669);border-color:#047857}body.dark-mode .model-detail-expanded.public-model.investment-save-btn{background:linear-gradient(135deg,#059669,#10b981);border-color:#059669}body.dark-mode .model-detail-expanded.public-model.investment-save-btn:hover{background:linear-gradient(135deg,#047857,#059669)}body.dark-mode .model-detail-expanded.public-model.holdings-edit-btn{color:#10b981;border-color:#10b9814d}body.dark-mode .model-detail-expanded.public-model.holdings-edit-btn:hover{background:#10b98126;border-color:#10b981}body.dark-mode .model-detail-expanded.public-model.mini-metric-value.positive,body.dark-mode .model-detail-expanded.public-model.sparkline-path.positive{color:#10b981;stroke:#10b981}.model-performance-chart{padding:16px;width:100%;max-width:100%;overflow:hidden;container-type:inline-size;container-name:perf-chart}.chart-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px;flex-wrap:wrap;gap:16px}.chart-header h4{margin:0;font-size:18px;font-weight:600;color:var(--text-primary)}body.dark-mode .chart-header h4{color:var(--text-primary-dark)}.performance-toggle-btn{background:none;border:none;font-size:14px;color:var(--text-secondary);cursor:pointer;padding:4px 8px;transition:color .2s}body.dark-mode .performance-toggle-btn{color:var(--text-secondary-dark)}.performance-toggle-btn:hover{color:var(--text-primary)}body.dark-mode .performance-toggle-btn:hover{color:var(--text-primary-dark)}.chart-controls{display:flex;flex-direction:column;gap:12px;width:100%}.control-group{display:flex;flex-direction:column;gap:8px}.control-label{font-size:13px;font-weight:600;color:var(--text-secondary)}body.dark-mode .control-label{color:var(--text-secondary-dark)}.benchmark-selector,.timeframe-selector{display:flex;flex-wrap:wrap;gap:8px}.benchmark-pill,.timeframe-pill,.timeframe-btn{padding:8px 14px;border-radius:8px;font-size:13px;font-weight:600;cursor:pointer;transition:all .2s;border:2px solid #d1d5db;background:#fff;color:#374151}body.dark-mode .benchmark-pill,body.dark-mode .timeframe-pill,body.dark-mode .timeframe-btn{border-color:#4b5563;background:#1f2937;color:#9ca3af}.benchmark-pill.active,.timeframe-pill.active,.timeframe-btn.active{background-color:#3b82f6!important;color:#fff!important;border-color:#3b82f6!important;font-weight:700;box-shadow:0 2px 8px #3b82f666}body.dark-mode .benchmark-pill.active,body.dark-mode .timeframe-pill.active,body.dark-mode .timeframe-btn.active{background-color:#2563eb!important;color:#fff!important;border-color:#2563eb!important;box-shadow:0 2px 8px #2563eb80}.benchmark-pill:hover:not(.active),.timeframe-pill:hover:not(.active),.timeframe-btn:hover:not(.active){background-color:#f3f4f6;border-color:#3b82f6;color:#1f2937}body.dark-mode .benchmark-pill:hover:not(.active),body.dark-mode .timeframe-pill:hover:not(.active),body.dark-mode .timeframe-btn:hover:not(.active){background-color:#374151;border-color:#60a5fa;color:#f9fafb}.benchmark-selector select{padding:8px 12px;border-radius:8px;border:1px solid var(--border-color);background:var(--bg-secondary);color:var(--text-primary);font-size:14px;cursor:pointer}.model-performance-chart .performance-stats{display:grid;grid-template-columns:repeat(3,1fr);gap:20px;margin-top:20px;width:100%}@media (max-width: 768px){.model-performance-chart .performance-stats{grid-template-columns:1fr!important}}@container (max-width: 400px){.model-performance-chart .performance-stats{grid-template-columns:1fr!important}}.model-performance-chart .stat-card,.model-performance-chart .stat-item{background:var(--background-primary);border-radius:6px;padding:16px;display:flex;flex-direction:column;gap:8px;border:1px solid var(--border-color);transition:transform .2s ease,box-shadow .2s ease;min-width:0}.model-performance-chart .stat-item:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}.stat-label{font-size:11px;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.8px}body.dark-mode .stat-label{color:var(--text-secondary-dark)}.stat-value{font-size:24px;font-weight:700;line-height:1}.model-chart-container{margin-top:20px;background:var(--bg-primary);border-radius:12px;padding:20px}@container perf-chart (max-width: 600px){.model-chart-container{padding:8px 2px;margin-top:8px}.model-performance-chart{padding:2px}}.performance-chart-container{margin-top:16px}.performance-loading,.performance-error,.chart-loading,.chart-error{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px;gap:12px}.performance-loading p,.performance-error p,.chart-loading p,.chart-error p{color:var(--text-secondary);font-size:14px;margin:0}.spinner,.loading-spinner{width:40px;height:40px;border:3px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.chart-skeleton{margin-top:20px;padding:20px;background:var(--bg-primary);border-radius:12px;border:1px solid var(--border-color)}.skeleton-chart-area{width:100%;height:350px;background:var(--bg-secondary);border-radius:8px;position:relative;overflow:hidden;margin-bottom:24px}.skeleton-shimmer{position:absolute;top:0;left:0;right:0;bottom:0;background:linear-gradient(90deg,transparent 0%,var(--bg-primary) 50%,transparent 100%);opacity:.6;animation:shimmerSlide 2s ease-in-out infinite}.skeleton-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:12px}@media (max-width: 768px){.skeleton-metrics{grid-template-columns:1fr}.skeleton-chart-area{height:250px}}.skeleton-metric-card{height:80px;background:var(--bg-secondary);border-radius:8px;border:1px solid var(--border-color);position:relative;overflow:hidden}.skeleton-loading-indicator{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;gap:12px;z-index:1}.skeleton-loading-indicator .loading-spinner{width:32px;height:32px;border-width:2px}.skeleton-loading-indicator p{color:var(--text-secondary);font-size:13px;font-weight:500;margin:0}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes shimmerSlide{0%{transform:translate(-100%)}to{transform:translate(100%)}}.chart-error button{margin-top:12px;padding:10px 20px;border-radius:8px;border:none;background-color:var(--primary-color);color:#fff;font-weight:600;cursor:pointer;transition:background-color .2s}.chart-error button:hover{background-color:#2563eb}.chart-tooltip{background:var(--bg-secondary);border:1px solid var(--border-color);border-radius:8px;padding:12px;box-shadow:0 4px 12px #0000001a}.tooltip-date{font-size:12px;font-weight:600;color:var(--text-secondary);margin:0 0 6px}.chart-tooltip p{margin:4px 0;font-size:13px}@media (max-width: 768px){.model-performance-chart{padding:4px}.chart-header{flex-direction:column;align-items:flex-start;gap:12px;margin-bottom:12px}.chart-header h4{font-size:16px}.chart-controls{width:100%}.timeframe-selector{justify-content:flex-start}.timeframe-btn{padding:10px 12px;font-size:12px;flex:0 1 auto;min-width:44px}.model-performance-chart .performance-stats{grid-template-columns:1fr!important;gap:12px;margin-top:12px}.model-performance-chart .stat-card,.model-performance-chart .stat-item{padding:12px}.stat-label{font-size:10px}.stat-value{font-size:20px}.model-chart-container{padding:8px 4px;margin-top:12px}.performance-chart-container{margin-top:8px;overflow-x:auto}}@media (max-width: 480px){.model-performance-chart{padding:2px}.timeframe-btn{padding:8px 10px;font-size:11px}.stat-value{font-size:18px}.model-chart-container{padding:4px 2px;margin-top:8px;border-radius:8px}.chart-header{margin-bottom:8px}}.performance-metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:12px;margin:20px 0}@media (max-width: 768px){.performance-metrics-grid{grid-template-columns:repeat(2,1fr)}}@media (max-width: 480px){.performance-metrics-grid{grid-template-columns:1fr}}.metric-card{display:flex;flex-direction:column;gap:6px;padding:14px;background:var(--bg-secondary, #f9fafb);border-radius:8px;border:1px solid var(--border-color, #e5e7eb);transition:transform .15s ease,box-shadow .15s ease}.metric-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #00000014}body.dark-mode .metric-card{background:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-color-dark, #444)}body.dark-mode .metric-card:hover{box-shadow:0 4px 12px #0000004d}.metric-label{font-size:11px;color:var(--text-secondary, #6b7280);font-weight:600;text-transform:uppercase;letter-spacing:.5px}body.dark-mode .metric-label{color:var(--text-secondary-dark, #9ca3af)}.metric-value{font-size:24px;font-weight:700;color:var(--text-primary, #111827);line-height:1.2}body.dark-mode .metric-value{color:var(--text-primary-dark, #f9fafb)}.metric-value.positive{color:#10b981}.metric-value.negative{color:#ef4444}.metric-secondary{font-size:13px;font-weight:500;color:var(--text-secondary, #6b7280);margin-top:2px}body.dark-mode .metric-secondary{color:var(--text-secondary-dark, #9ca3af)}.portfolio-metrics-section{margin:24px 0;padding:20px;background:linear-gradient(135deg,#3b82f60d,#9333ea0d);border-left:4px solid #3b82f6;border-radius:12px}body.dark-mode .portfolio-metrics-section{background:linear-gradient(135deg,#3b82f614,#9333ea14);border-left-color:#2563eb}.strategy-metrics-section{margin:24px 0;padding:20px;background:linear-gradient(135deg,#10b9810d,#3b82f60d);border-left:4px solid #10b981;border-radius:12px}body.dark-mode .strategy-metrics-section{background:linear-gradient(135deg,#10b98114,#3b82f614);border-left-color:#059669}.metrics-section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px;flex-wrap:wrap;gap:8px}.metrics-section-header h3{font-size:16px;font-weight:700;color:var(--text-primary, #111827);margin:0;text-transform:uppercase;letter-spacing:.5px}body.dark-mode .metrics-section-header h3{color:var(--text-primary-dark, #f9fafb)}.metrics-date,.metrics-timeframe{font-size:12px;font-weight:600;color:var(--text-secondary, #6b7280);background:#ffffffb3;padding:4px 12px;border-radius:12px;border:1px solid var(--border-color, #e5e7eb)}body.dark-mode .metrics-date,body.dark-mode .metrics-timeframe{color:var(--text-secondary-dark, #9ca3af);background:#0000004d;border-color:var(--border-color-dark, #444)}.portfolio-metrics-section .metric-card,.strategy-metrics-section .metric-card{background:var(--bg-primary, white);border:1px solid rgba(59,130,246,.2)}body.dark-mode .portfolio-metrics-section .metric-card,body.dark-mode .strategy-metrics-section .metric-card{background:var(--bg-secondary-dark, #0f0f0f);border-color:#3b82f64d}.strategy-metrics-section .metric-card{border-color:#10b98133}body.dark-mode .strategy-metrics-section .metric-card{border-color:#10b9814d}.model-holdings-wrapper{width:100%;overflow-x:auto;background:var(--bg-secondary, #ffffff);border-radius:8px;padding:16px}.model-holdings-container{width:100%}.model-holdings-table{width:100%;border-collapse:collapse;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,sans-serif}.model-holdings-table th,.model-holdings-table td{padding:12px 8px;text-align:left;border-bottom:1px solid var(--border-color, #e5e7eb);vertical-align:middle}.model-holdings-table th{font-weight:600;background-color:var(--bg-secondary, #f9fafb);color:var(--text-secondary, #6b7280);font-size:11px;text-transform:uppercase;letter-spacing:.05em;border-bottom:2px solid var(--border-color, #e5e7eb)}.model-holdings-table td{font-size:14px;color:var(--text-primary, #1f2937);font-weight:500}.model-holdings-table th.text-right,.model-holdings-table td.text-right{text-align:right}.model-holdings-table th.sortable{cursor:pointer;-webkit-user-select:none;user-select:none;transition:background-color .2s ease}.model-holdings-table th.sortable:hover{background-color:var(--hover-background, #f3f4f6)}.model-holdings-table tbody tr{transition:background-color .15s ease}.model-holdings-table tbody tr:hover{background-color:var(--hover-background, #f9fafb)}.model-holdings-table tbody tr:last-child td{border-bottom:none}.model-holdings-table .ticker-cell.ticker-bold{font-weight:700;color:var(--primary-color, #3b82f6);text-decoration:none}.model-holdings-table .currency-cell{color:var(--text-secondary, #9ca3af);font-size:13px}.model-holdings-table .percentage-text{font-weight:600;color:var(--text-primary, #1f2937)}.performance-positive{color:#10b981;font-weight:600}.performance-negative{color:#ef4444;font-weight:600}.stacked-cell{display:flex;flex-direction:column;align-items:flex-end;gap:2px;justify-content:center}.stacked-cell .cell-main-value{font-size:14px;font-weight:600;line-height:1.2}.stacked-cell .cell-sub-value{font-size:12px;font-weight:500;opacity:.85;line-height:1}.model-holdings-table tfoot{border-top:2px solid var(--border-color, #d1d5db)}.model-holdings-table tfoot tr.totals-row{background-color:var(--bg-secondary, #f9fafb);font-weight:600}.model-holdings-table tfoot tr.totals-row:hover{background-color:var(--bg-secondary, #f9fafb)}.model-holdings-table tfoot td{padding:14px 8px;border-bottom:none;font-weight:600}.model-holdings-table .totals-label{color:var(--text-primary, #1f2937);font-size:14px}body.dark-mode .model-holdings-table tfoot{border-top-color:var(--border-color-dark, #4b5563)}body.dark-mode .model-holdings-table tfoot tr.totals-row,body.dark-mode .model-holdings-table tfoot tr.totals-row:hover{background-color:var(--bg-secondary-dark, #374151)}body.dark-mode .model-holdings-table .totals-label{color:var(--text-primary-dark, #f9fafb)}.model-holdings-footer{margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color, #e5e7eb);font-size:12px;font-weight:500;color:var(--text-secondary, #6b7280)}body.dark-mode .model-holdings-wrapper{background:var(--bg-secondary-dark, #1f2937)}body.dark-mode .model-holdings-table th{background-color:var(--bg-secondary-dark, #374151);color:var(--text-secondary-dark, #9ca3af);border-bottom-color:var(--border-color-dark, #4b5563)}body.dark-mode .model-holdings-table td{color:var(--text-primary-dark, #f9fafb);border-bottom-color:var(--border-color-dark, #374151)}body.dark-mode .model-holdings-table tbody tr:hover{background-color:var(--hover-background-dark, #374151)}body.dark-mode .model-holdings-table .ticker-cell.ticker-bold{color:var(--primary-color, #60a5fa)}body.dark-mode .model-holdings-table .currency-cell{color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .model-holdings-footer{border-top-color:var(--border-color-dark, #374151);color:var(--text-secondary-dark, #9ca3af)}.model-strategy-card-inline{padding:20px;background-color:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;margin:12px 0}body.dark-mode .model-strategy-card-inline{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.model-strategy-inline-header{display:flex;align-items:flex-start;gap:12px;margin-bottom:12px}.strategy-icon{font-size:32px;flex-shrink:0}.strategy-title-section{flex:1}.strategy-title-section h3{font-size:20px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 4px}body.dark-mode .strategy-title-section h3{color:var(--text-primary-dark, #f9fafb)}.strategy-mode{font-size:14px;color:var(--text-secondary, #6b7280);margin:0}body.dark-mode .strategy-mode{color:var(--text-secondary-dark, #9ca3af)}.strategy-description{font-size:14px;color:var(--text-secondary, #6b7280);margin:0 0 16px;line-height:1.5}body.dark-mode .strategy-description{color:var(--text-secondary-dark, #9ca3af)}.strategy-expand-btn{width:100%;padding:12px;background-color:var(--primary-color, #3b82f6);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.strategy-expand-btn:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.strategy-expand-btn:active{transform:translateY(0)}@media (max-width: 768px){.model-strategy-card-inline{padding:16px}.strategy-icon{font-size:28px}.strategy-title-section h3{font-size:18px}}.model-strategy-expanded{display:flex;flex-direction:column;height:100%}.strategy-expanded-header{padding-bottom:20px;border-bottom:1px solid var(--border-color, #e5e7eb);margin-bottom:24px}body.dark-mode .strategy-expanded-header{border-bottom-color:var(--border-color-dark, #444)}.strategy-expanded-title{font-size:24px;font-weight:700;color:var(--text-primary, #111827);margin:0 0 4px}body.dark-mode .strategy-expanded-title{color:var(--text-primary-dark, #f9fafb)}.strategy-mode-indicator{font-size:14px;color:var(--text-secondary, #6b7280);margin:0}body.dark-mode .strategy-mode-indicator{color:var(--text-secondary-dark, #9ca3af)}.strategy-form{flex:1;overflow-y:auto}.form-section{margin-bottom:24px}.section-label{display:block;font-size:14px;font-weight:600;color:var(--text-primary, #111827);margin-bottom:12px}body.dark-mode .section-label{color:var(--text-primary-dark, #f9fafb)}.section-header-with-toggle{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.radio-group{display:flex;flex-direction:column;gap:10px}.radio-option{display:flex;align-items:flex-start;gap:12px;padding:12px;background-color:var(--bg-secondary, #f9fafb);border:2px solid var(--border-color, #e5e7eb);border-radius:8px;cursor:pointer;transition:all .2s ease}.radio-option:hover{border-color:var(--primary-color, #3b82f6);background-color:var(--bg-hover, #f3f4f6)}.radio-option:has(input:checked){border-color:var(--primary-color, #3b82f6);background-color:#eff6ff}body.dark-mode .radio-option{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}body.dark-mode .radio-option:hover{background-color:var(--bg-hover-dark, #3a3a3a)}body.dark-mode .radio-option:has(input:checked){background-color:#1e3a8a}.radio-option input[type=radio]{margin-top:2px;width:18px;height:18px;cursor:pointer}.radio-content{display:flex;flex-direction:column;gap:4px;flex:1}.radio-label{font-size:15px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .radio-label{color:var(--text-primary-dark, #f9fafb)}.radio-description{font-size:13px;color:var(--text-secondary, #6b7280)}body.dark-mode .radio-description{color:var(--text-secondary-dark, #9ca3af)}.chip-group{display:flex;flex-wrap:wrap;gap:8px}.chip{padding:8px 16px;background-color:var(--bg-secondary, #f9fafb);border:2px solid var(--border-color, #e5e7eb);border-radius:20px;font-size:14px;font-weight:500;color:var(--text-primary, #111827);cursor:pointer;transition:all .2s ease;display:flex;align-items:center;gap:6px}.chip:hover{border-color:var(--primary-color, #3b82f6);background-color:var(--bg-hover, #f3f4f6)}.chip.selected{background-color:var(--primary-color, #3b82f6);border-color:var(--primary-color, #3b82f6);color:#fff}body.dark-mode .chip{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .chip:hover{background-color:var(--bg-hover-dark, #3a3a3a)}.chip-icon{font-size:16px}.toggle-switch{position:relative;display:inline-block;width:48px;height:26px}.toggle-switch input{opacity:0;width:0;height:0}.toggle-slider{position:absolute;cursor:pointer;top:0;left:0;right:0;bottom:0;background-color:var(--border-color, #d1d5db);transition:.3s;border-radius:26px}.toggle-slider:before{position:absolute;content:"";height:20px;width:20px;left:3px;bottom:3px;background-color:#fff;transition:.3s;border-radius:50%}input:checked+.toggle-slider{background-color:var(--primary-color, #3b82f6)}input:checked+.toggle-slider:before{transform:translate(22px)}body.dark-mode .toggle-slider{background-color:var(--border-color-dark, #555)}.select-input{width:100%;padding:12px;background-color:var(--bg-secondary, #f9fafb);border:2px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:15px;color:var(--text-primary, #111827);cursor:pointer;transition:all .2s ease}.select-input:hover{border-color:var(--primary-color, #3b82f6)}.select-input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}body.dark-mode .select-input{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}.textarea-input{width:100%;padding:12px;background-color:var(--bg-secondary, #f9fafb);border:2px solid var(--border-color, #e5e7eb);border-radius:8px;font-size:15px;font-family:inherit;color:var(--text-primary, #111827);resize:vertical;transition:all .2s ease}.textarea-input:hover{border-color:var(--primary-color, #3b82f6)}.textarea-input:focus{outline:none;border-color:var(--primary-color, #3b82f6);box-shadow:0 0 0 3px #3b82f61a}.textarea-input::placeholder{color:var(--text-secondary, #9ca3af)}body.dark-mode .textarea-input{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .textarea-input::placeholder{color:var(--text-secondary-dark, #6b7280)}.form-actions{display:flex;gap:12px;padding-top:24px;border-top:1px solid var(--border-color, #e5e7eb);margin-top:24px}body.dark-mode .form-actions{border-top-color:var(--border-color-dark, #444)}.form-btn{flex:1;padding:14px 20px;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.form-btn.cancel{background-color:transparent;border:2px solid var(--border-color, #d1d5db);color:var(--text-primary, #111827)}.form-btn.cancel:hover{background-color:var(--bg-hover, #f3f4f6);border-color:var(--text-secondary, #9ca3af)}body.dark-mode .form-btn.cancel{border-color:var(--border-color-dark, #444);color:var(--text-primary-dark, #f9fafb)}body.dark-mode .form-btn.cancel:hover{background-color:var(--bg-hover-dark, #3a3a3a)}.form-btn.submit{background-color:var(--primary-color, #3b82f6);color:#fff}.form-btn.submit:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.form-btn:active{transform:translateY(0)}@media (max-width: 768px){.strategy-expanded-title{font-size:20px}.form-section{margin-bottom:20px}.chip-group{gap:6px}.chip{padding:6px 12px;font-size:13px}.form-actions{flex-direction:column}.form-btn{width:100%}}.market-report-card-inline{padding:20px;background-color:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;margin:12px 0}body.dark-mode .market-report-card-inline{background-color:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.market-report-inline-header{margin-bottom:16px}.market-status{display:flex;align-items:center;gap:8px}.status-indicator{width:10px;height:10px;border-radius:50%;animation:pulse 2s infinite}.status-indicator.open{background-color:#10b981;box-shadow:0 0 8px #10b98180}.status-indicator.closed{background-color:#ef4444}@keyframes pulse{0%,to{opacity:1}50%{opacity:.6}}.status-text{font-size:14px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .status-text{color:var(--text-primary-dark, #f9fafb)}.indices-summary{display:grid;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));gap:12px;margin-bottom:16px}.index-mini{padding:12px;background-color:#fff;border:1px solid var(--border-color, #e5e7eb);border-radius:8px}body.dark-mode .index-mini{background-color:var(--bg-primary-dark, #1a1a1a);border-color:var(--border-color-dark, #444)}.index-mini-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:6px}.index-symbol{font-size:12px;font-weight:700;color:var(--text-primary, #111827);font-family:SF Mono,Monaco,Consolas,monospace}body.dark-mode .index-symbol{color:var(--text-primary-dark, #f9fafb)}.index-change{font-size:11px;font-weight:600}.index-change.neutral{color:var(--text-secondary, #6b7280)}.index-value{font-size:14px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .index-value{color:var(--text-primary-dark, #f9fafb)}.market-expand-btn{width:100%;padding:12px;background-color:var(--primary-color, #3b82f6);color:#fff;border:none;border-radius:8px;font-size:15px;font-weight:600;cursor:pointer;transition:all .2s ease;display:flex;align-items:center;justify-content:center;gap:8px}.market-expand-btn:hover{background-color:#2563eb;transform:translateY(-1px);box-shadow:0 4px 12px #3b82f64d}.market-expand-btn:active{transform:translateY(0)}@media (max-width: 768px){.market-report-card-inline{padding:16px}.indices-summary{grid-template-columns:1fr;gap:10px}.index-mini{padding:10px}}.market-report-expanded{display:flex;flex-direction:column;height:100%;overflow-y:auto;padding:20px;background:var(--bg-primary, white)}body.dark-mode .market-report-expanded{background:var(--bg-primary-dark, #1a1a1a)}.market-report-header{display:flex;justify-content:space-between;align-items:center;padding-bottom:20px;border-bottom:1px solid var(--border-color, #e5e7eb);margin-bottom:20px}body.dark-mode .market-report-header{border-bottom-color:var(--border-color-dark, #444)}.market-report-title{font-size:24px;font-weight:700;color:var(--text-primary, #111827);margin:0}body.dark-mode .market-report-title{color:var(--text-primary-dark, #f9fafb)}.close-btn{background:transparent;border:1px solid var(--border-color, #e5e7eb);border-radius:6px;padding:8px 12px;font-size:16px;color:var(--text-secondary, #6b7280);cursor:pointer;transition:all .2s ease}.close-btn:hover{background:var(--bg-hover, #f3f4f6);color:var(--text-primary, #111827);border-color:var(--primary-color, #3b82f6)}body.dark-mode .close-btn{color:var(--text-secondary-dark, #9ca3af);border-color:var(--border-color-dark, #444)}body.dark-mode .close-btn:hover{background:var(--bg-hover-dark, #3a3a3a);color:var(--text-primary-dark, #f9fafb)}.market-report-content{display:flex;flex-direction:column;gap:24px}.portfolio-card-expanded{background:var(--bg-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:10px;padding:16px}body.dark-mode .portfolio-card-expanded{background:var(--bg-secondary-dark, #2a2a2a);border-color:var(--border-color-dark, #444)}.portfolio-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px}.portfolio-name{font-size:16px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .portfolio-name{color:var(--text-primary-dark, #f9fafb)}.portfolio-type{font-size:12px;padding:4px 8px;border-radius:12px;font-weight:500}.portfolio-type.ai{background:#3b82f61a;color:#3b82f6}.portfolio-type.personal{background:#10b9811a;color:#10b981}.portfolio-stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.portfolio-stat{display:flex;flex-direction:column;gap:4px}.stat-label{font-size:12px;color:var(--text-secondary, #6b7280)}body.dark-mode .stat-label{color:var(--text-secondary-dark, #9ca3af)}.stat-value{font-size:16px;font-weight:600;color:var(--text-primary, #111827)}body.dark-mode .stat-value{color:var(--text-primary-dark, #f9fafb)}.stat-percent{font-size:12px;font-weight:400;margin-left:4px}@media (max-width: 768px){.market-report-expanded{padding:16px}.market-report-title{font-size:20px}.portfolio-stats-grid{grid-template-columns:1fr}}.suggested-questions-container{margin:20px 0;padding:16px 0}.suggested-questions-header{font-size:13px;font-weight:600;color:var(--text-secondary, #6b7280);margin-bottom:12px;letter-spacing:.3px;text-transform:none}.suggested-questions-list{display:flex;flex-direction:column;gap:0px}.question-item{display:flex;align-items:flex-start;gap:10px;padding:10px 14px;background-color:transparent;border:none;border-radius:8px;font-size:14px;font-weight:400;line-height:1.5;color:var(--text-primary, #111827);cursor:pointer;transition:all .15s ease;text-align:left;width:100%}.question-arrow{color:var(--text-secondary, #6b7280);font-size:16px;flex-shrink:0;margin-top:1px;transition:transform .15s ease,color .15s ease}.question-text{flex:1;word-wrap:break-word}.question-item:hover{background-color:var(--bg-secondary, #f9fafb);transform:translate(4px)}.question-item:hover .question-arrow{color:var(--primary-color, #3b82f6);transform:translate(2px)}.question-item:active{transform:translate(2px)}body.dark-mode .suggested-questions-header{color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .question-item{color:var(--text-primary-dark, #f9fafb)}body.dark-mode .question-arrow{color:var(--text-secondary-dark, #9ca3af)}body.dark-mode .question-item:hover{background-color:var(--bg-secondary-dark, #2a2a2a)}body.dark-mode .question-item:hover .question-arrow{color:var(--primary-color, #3b82f6)}@media (max-width: 768px){.suggested-questions-container{margin:16px 0;padding:12px 0}.suggested-questions-header{font-size:12px;margin-bottom:10px}.question-item{padding:8px 12px;font-size:13px;gap:8px}.question-arrow{font-size:14px}}.compact-placeholder-wrapper{display:flex;justify-content:center;margin:12px 0}.compact-placeholder{display:flex;align-items:center;gap:12px;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:var(--radius-lg);padding:8px 16px;cursor:pointer;transition:all var(--transition-base);box-shadow:var(--shadow-sm);width:33%;min-width:280px;max-width:400px}.compact-placeholder:hover{background:var(--bg-secondary);border-color:var(--accent-primary);transform:translateY(-1px);box-shadow:var(--shadow-md)}.compact-placeholder-icon{font-size:18px;flex-shrink:0}.compact-placeholder-content{flex:1;display:flex;flex-direction:column;gap:2px;min-width:0}.compact-placeholder-name{font-size:var(--font-sm);font-weight:600;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-placeholder-meta{font-size:var(--font-xs);color:var(--text-secondary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.compact-placeholder-arrow{color:var(--text-secondary);font-size:16px;flex-shrink:0;transition:transform var(--transition-fast)}.compact-placeholder:hover .compact-placeholder-arrow{transform:translate(2px);color:var(--accent-primary)}@media (max-width: 1024px){.compact-placeholder{width:50%;min-width:260px}}@media (max-width: 768px){.compact-placeholder-wrapper{margin:10px 0}.compact-placeholder{width:90%;max-width:none;padding:6px 14px}.compact-placeholder-icon{font-size:16px}.compact-placeholder-name{font-size:13px}.compact-placeholder-meta{font-size:11px}}@media (max-width: 480px){.compact-placeholder{width:95%;min-width:unset}}body.dark-mode .compact-placeholder,[data-theme=dark] .compact-placeholder{background:var(--bg-primary);border-color:var(--border-primary);box-shadow:var(--shadow-sm)}body.dark-mode .compact-placeholder:hover,[data-theme=dark] .compact-placeholder:hover{background:var(--bg-secondary);border-color:var(--accent-primary);box-shadow:var(--shadow-md)}body.dark-mode .compact-placeholder-name,[data-theme=dark] .compact-placeholder-name{color:var(--text-primary)}body.dark-mode .compact-placeholder-meta,[data-theme=dark] .compact-placeholder-meta,body.dark-mode .compact-placeholder-arrow,[data-theme=dark] .compact-placeholder-arrow{color:var(--text-secondary)}body.dark-mode .compact-placeholder:hover .compact-placeholder-arrow,[data-theme=dark] .compact-placeholder:hover .compact-placeholder-arrow{color:var(--accent-primary)}.billing-dashboard{padding:20px;max-width:1200px;margin:0 auto}.billing-header{margin-bottom:30px}.billing-header h2{font-size:28px;font-weight:600;color:var(--text-primary);margin:0}.balance-card{background:var(--card-background);border-radius:12px;padding:24px;margin-bottom:20px;border:2px solid var(--border-color);transition:all .3s ease}.balance-card.low{border-color:#ef4444;background:linear-gradient(135deg,rgba(239,68,68,.05) 0%,var(--card-background) 100%)}.balance-card.medium{border-color:#f59e0b;background:linear-gradient(135deg,rgba(245,158,11,.05) 0%,var(--card-background) 100%)}.balance-card.good{border-color:#10b981;background:linear-gradient(135deg,rgba(16,185,129,.05) 0%,var(--card-background) 100%)}.balance-info{display:flex;flex-direction:column;gap:8px;margin-bottom:20px}.balance-label{font-size:14px;color:var(--text-secondary);font-weight:500}.balance-amount{font-size:48px;font-weight:700;color:var(--text-primary);line-height:1}.balance-warning{font-size:14px;color:#ef4444;font-weight:600}.balance-actions{display:flex;gap:12px;flex-wrap:wrap}.add-credits-btn{padding:12px 24px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-credits-btn:hover{background:var(--primary-hover);transform:translateY(-2px)}.add-credits-btn.small{padding:10px 20px;font-size:14px}.payment-method-card{background:var(--card-background);border-radius:12px;padding:24px;margin-bottom:20px;border:2px solid var(--border-color)}.payment-method-info{display:flex;flex-direction:column;gap:16px}.payment-method-actions{display:flex;gap:12px;flex-wrap:wrap}.no-payment-method,.has-payment-method{display:flex;align-items:center;gap:12px;padding:16px;border-radius:8px;background:var(--background-secondary)}.no-payment-method .icon{font-size:32px}.has-payment-method{border:2px solid #10b981;background:#10b9810d}.has-payment-method .icon.success{font-size:32px;color:#10b981}.no-payment-method p,.has-payment-method p{margin:0;font-size:16px;font-weight:600;color:var(--text-primary)}.add-payment-btn,.update-payment-btn{padding:14px 24px;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.add-payment-btn:hover,.update-payment-btn:hover{background:var(--primary-hover);transform:translateY(-2px)}.update-payment-btn.secondary{background:var(--border-color);color:var(--text-primary)}.update-payment-btn.secondary:hover{background:var(--hover-background)}.cancel-service-btn{padding:14px 24px;background:transparent;color:#ef4444;border:2px solid #ef4444;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:all .2s ease}.cancel-service-btn:hover{background:#ef44441a;transform:translateY(-2px)}.payment-note{font-size:14px;color:var(--text-secondary);margin:0;line-height:1.5}.info-note.warning{background:#f59e0b1a;color:#f59e0b}.auto-reload-card{background:var(--card-background);border-radius:12px;padding:24px;margin-bottom:20px;border:2px solid var(--border-color)}.card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.card-header h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.status-badge{padding:6px 16px;border-radius:20px;font-size:14px;font-weight:600}.status-badge.active{background:#10b98126;color:#10b981;border:2px solid #10b981}.toggle-button{padding:8px 16px;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease;border:2px solid}.toggle-button.enabled{background:#10b981;color:#fff;border-color:#10b981}.toggle-button.disabled{background:transparent;color:var(--text-secondary);border-color:var(--border-color)}.toggle-button:hover{transform:translateY(-2px)}.toggle-button:disabled{opacity:.5;cursor:not-allowed;transform:none}.auto-reload-info p{margin:8px 0;color:var(--text-secondary);line-height:1.6}.auto-reload-description{font-size:16px;margin-bottom:16px!important;color:var(--text-primary)!important}.auto-reload-explainer{margin-top:20px;padding:16px;background:var(--background-secondary);border-radius:8px;border-left:4px solid var(--primary-color)}.explainer-text{font-size:14px;line-height:1.6;margin:0;color:var(--text-secondary)}.info-note{padding:12px;background:#3b82f61a;border-radius:6px;font-size:14px;color:#3b82f6;margin-top:12px}.info-note.success{background:#10b9811a;color:#10b981}.usage-stats-card{background:var(--card-background);border-radius:12px;padding:24px;border:2px solid var(--border-color)}.usage-stats-card h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 20px}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:20px}.stat-item{display:flex;flex-direction:column;gap:8px}.stat-label{font-size:14px;color:var(--text-secondary);font-weight:500}.stat-value{font-size:24px;font-weight:700;color:var(--text-primary)}.transaction-history{margin-top:30px}.history-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.history-header h3{font-size:20px;font-weight:600;color:var(--text-primary);margin:0}.limit-select{padding:8px 12px;border-radius:6px;border:2px solid var(--border-color);background:var(--card-background);color:var(--text-primary);font-size:14px;cursor:pointer}.transactions-table{overflow-x:auto;background:var(--card-background);border-radius:12px;border:2px solid var(--border-color)}.transactions-table table{width:100%;border-collapse:collapse}.transactions-table th{text-align:left;padding:16px;font-size:14px;font-weight:600;color:var(--text-secondary);border-bottom:2px solid var(--border-color);background:var(--background-secondary)}.transactions-table td{padding:16px;font-size:14px;color:var(--text-primary);border-bottom:1px solid var(--border-color)}.transactions-table tr:last-child td{border-bottom:none}.transactions-table tr:hover{background:var(--hover-background)}.model-info{display:flex;flex-direction:column;gap:4px}.provider-name{font-weight:600;color:var(--text-primary)}.model-name{font-size:12px;color:var(--text-secondary)}.token-breakdown{display:flex;flex-direction:column;gap:4px}.token-count{font-weight:600}.token-detail{font-size:12px;color:var(--text-secondary)}.cache-info{display:flex;gap:8px;font-size:12px}.cache-write{color:#f59e0b}.cache-read{color:#10b981}.search-count{font-size:12px;color:#3b82f6}.cost-cell{font-weight:600;color:var(--text-primary)}.balance-cell{color:var(--text-secondary)}.payment-setup-card{display:flex;gap:20px;padding:24px;background:linear-gradient(135deg,rgba(59,130,246,.05) 0%,var(--card-background) 100%);border:2px solid #3b82f6;border-radius:12px;margin:20px 0;max-width:600px}.card-icon{font-size:48px;line-height:1}.card-content{flex:1}.card-title{font-size:20px;font-weight:600;color:var(--text-primary);margin:0 0 8px}.card-message{font-size:14px;color:var(--text-secondary);line-height:1.6;margin:0 0 16px}.payment-options{display:flex;gap:12px;margin-bottom:12px;flex-wrap:wrap}.payment-btn{padding:12px 20px;background:#3b82f6;color:#fff;border:none;border-radius:8px;font-size:14px;font-weight:600;cursor:pointer;transition:all .2s ease}.payment-btn:hover{background:#2563eb;transform:translateY(-2px)}.payment-btn:disabled{opacity:.5;cursor:not-allowed;transform:none}.payment-btn.small{padding:10px 16px;font-size:13px}.payment-btn.large{background:#10b981;padding:12px 24px}.payment-btn.large:hover{background:#059669}.card-footer{font-size:12px;color:var(--text-secondary);margin:0}.billing-dashboard.loading,.transaction-history.loading{display:flex;flex-direction:column;align-items:center;justify-content:center;padding:60px 20px}.spinner{width:40px;height:40px;border:4px solid var(--border-color);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite}.error-message{color:#ef4444;font-size:14px;margin:8px 0}.retry-button{padding:10px 20px;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:14px;font-weight:600;cursor:pointer;margin-top:12px}.retry-button:hover{background:var(--primary-hover)}@media (max-width: 768px){.billing-dashboard{padding:16px}.balance-amount{font-size:36px}.stats-grid{grid-template-columns:repeat(2,1fr)}.payment-setup-card{flex-direction:column;align-items:center;text-align:center}.payment-options{justify-content:center}.transactions-table{font-size:12px}.transactions-table th,.transactions-table td{padding:10px}}.message-dynamic-component{margin:8px 0}.market-indices-dynamic{background:var(--card-background, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:16px;margin:0}.market-indices-dynamic.loading{opacity:.6}.indices-carousel-wrapper{position:relative;display:flex;align-items:center;gap:12px;margin-bottom:12px}.indices-carousel-container{display:flex;gap:12px;overflow-x:auto;scroll-behavior:smooth;scrollbar-width:none;-ms-overflow-style:none;-webkit-overflow-scrolling:touch;flex:1;padding:4px 0}.indices-carousel-container::-webkit-scrollbar{display:none}.index-card{background:var(--background-secondary, #f9fafb);border-radius:8px;padding:16px;transition:transform .2s,box-shadow .2s;min-width:200px;flex-shrink:0}.index-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.index-card.skeleton{animation:pulse 1.5s ease-in-out infinite}.index-name{font-size:10px;font-weight:600;color:var(--text-secondary, #6b7280);text-transform:uppercase;letter-spacing:.5px;margin-bottom:6px}.index-price{font-size:18px;font-weight:700;color:var(--text-primary, #111827);margin-bottom:3px}.index-change{font-size:12px;font-weight:600;display:flex;align-items:center;gap:6px}.index-change.positive{color:#10b981}.index-change.negative{color:#ef4444}.change-percent{font-size:11px}.index-sparkline{width:100%;height:40px;margin-top:8px}.index-sparkline svg{width:100%;height:100%}.dynamic-movers{background:var(--card-background, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:16px;margin:0}.dynamic-movers.loading{opacity:.6}.movers-carousel-wrapper{position:relative;display:flex;align-items:center;gap:12px;margin-bottom:12px}.movers-carousel-container{display:flex;gap:10px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;padding:4px 0}.movers-carousel-container::-webkit-scrollbar{display:none}.carousel-nav{background:var(--card-background, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:50%;width:36px;height:36px;display:flex;align-items:center;justify-content:center;cursor:pointer;font-size:24px;font-weight:300;color:var(--text-primary, #111827);transition:all .2s;flex-shrink:0;z-index:10}.carousel-nav:hover{background:var(--background-secondary, #f9fafb);border-color:var(--text-tertiary, #9ca3af);transform:scale(1.1)}.carousel-nav:active{transform:scale(.95)}.movers-divider{width:2px;height:80px;background:linear-gradient(to bottom,transparent,var(--border-color, #e5e7eb) 20%,var(--border-color, #e5e7eb) 80%,transparent);flex-shrink:0;margin:0 8px}.mover-card{min-width:140px;background:var(--background-secondary, #f9fafb);border-radius:8px;padding:12px;flex-shrink:0;transition:transform .2s,box-shadow .2s;cursor:pointer;position:relative}.mover-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.mover-card-ticker{font-size:14px;font-weight:700;color:var(--text-primary, #111827);margin-bottom:4px}.mover-card-name{font-size:10px;color:var(--text-secondary, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;margin-bottom:8px;line-height:1.2}.mover-card-price{font-size:16px;font-weight:700;color:var(--text-primary, #111827);margin-bottom:4px}.mover-card-change{font-size:12px;font-weight:700;padding:3px 8px;border-radius:4px;display:inline-block}.mover-card-change.positive{color:#10b981;background:#10b98126}.mover-card-change.negative{color:#ef4444;background:#ef444426}.mover-item{display:flex;justify-content:space-between;align-items:center;padding:10px 12px;background:var(--card-background, #fff);border-radius:6px;transition:background .2s}.mover-item:hover{background:var(--background-hover, #f3f4f6)}.mover-item.skeleton{animation:pulse 1.5s ease-in-out infinite;height:48px}.mover-info{display:flex;flex-direction:column;gap:2px;flex:1}.mover-ticker{font-size:14px;font-weight:700;color:var(--text-primary, #111827)}.mover-name{font-size:12px;color:var(--text-secondary, #6b7280);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:200px}.mover-stats{display:flex;flex-direction:column;align-items:flex-end;gap:2px}.dynamic-movers .mover-price{display:block;font-size:14px;font-weight:600;color:var(--text-primary, #111827)}.dynamic-movers .mover-change{display:block;font-size:13px;font-weight:700;padding:2px 8px;border-radius:4px}.dynamic-movers .mover-change.positive{color:#10b981;background:#10b9811a}.dynamic-movers .mover-change.negative{color:#ef4444;background:#ef44441a}.data-freshness{display:flex;align-items:center;gap:8px;margin-top:12px;padding-top:12px;border-top:1px solid var(--border-color, #e5e7eb);font-size:11px;color:var(--text-secondary, #6b7280)}.freshness-badge{display:inline-flex;align-items:center;padding:2px 8px;background:#10b981;color:#fff;border-radius:12px;font-weight:600;font-size:10px;text-transform:uppercase;letter-spacing:.5px}.freshness-text{font-size:11px}.static-context{margin-bottom:12px;padding:12px;background:var(--background-tertiary, #f3f4f6);border-left:3px solid var(--brand-primary, #3b82f6);border-radius:4px;font-size:14px;color:var(--text-secondary, #6b7280);font-style:italic}.dynamic-portfolios-summary{background:var(--card-background, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:16px;margin:0}.dynamic-portfolios-summary.loading{opacity:.6}.portfolios-scroll-container{display:flex;gap:12px;overflow-x:auto;padding-bottom:8px;scrollbar-width:thin;margin-bottom:12px;scroll-behavior:smooth;-webkit-overflow-scrolling:touch}.portfolios-scroll-container::-webkit-scrollbar{height:6px}.portfolios-scroll-container::-webkit-scrollbar-track{background:var(--background-secondary, #f9fafb);border-radius:3px}.portfolios-scroll-container::-webkit-scrollbar-thumb{background:var(--border-color, #e5e7eb);border-radius:3px}.portfolios-scroll-container::-webkit-scrollbar-thumb:hover{background:var(--text-tertiary, #9ca3af)}.portfolio-summary-card{min-width:220px;background:var(--background-secondary, #f9fafb);border-radius:8px;padding:16px;flex-shrink:0;transition:transform .2s,box-shadow .2s;cursor:pointer}.portfolio-summary-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.portfolio-summary-card.skeleton{animation:pulse 1.5s ease-in-out infinite}.portfolio-summary-card.create-card{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:120px;border:2px dashed var(--border-color, #e5e7eb);background:var(--background-secondary, #f9fafb)}.portfolio-summary-card.create-card:hover{border-color:#34c759;background:var(--card-background, #fff);box-shadow:0 2px 8px #34c7591a}.create-card-icon{font-size:32px;margin-bottom:8px}.create-card-title{font-size:14px;font-weight:600;color:var(--text-primary, #111827);margin-bottom:4px;text-align:center}.create-card-subtitle{font-size:12px;color:var(--text-secondary, #6b7280);text-align:center}.portfolio-name{font-size:14px;font-weight:600;color:var(--text-primary, #111827);margin-bottom:8px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.portfolio-value{font-size:20px;font-weight:700;color:var(--text-primary, #111827);margin-bottom:4px}.portfolio-change{font-size:13px;font-weight:600;display:flex;align-items:center;gap:6px;margin-bottom:8px}.portfolio-change.positive{color:#10b981}.portfolio-change.negative{color:#ef4444}.change-amount{font-size:11px}.portfolio-pl{font-size:11px;font-weight:500}.portfolio-pl.positive{color:#10b981}.portfolio-pl.negative{color:#ef4444}.dynamic-portfolios-error{display:flex;align-items:center;gap:8px;padding:16px;background:var(--background-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;color:var(--text-secondary, #6b7280);font-size:14px}@media (max-width: 768px){.portfolio-summary-card{min-width:180px}.portfolio-value{font-size:18px}.mover-card{min-width:120px;padding:10px}.mover-card-price{font-size:14px}.mover-card-name{font-size:9px}.carousel-nav{width:32px;height:32px;font-size:20px}.movers-divider{height:70px}}.market-indices-error,.dynamic-movers-error{display:flex;align-items:center;gap:8px;padding:16px;background:#fef2f2;border:1px solid #fecaca;border-radius:8px;color:#991b1b;font-size:14px}.error-icon{font-size:20px}.skeleton-line{background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite;border-radius:4px;height:16px;margin-bottom:8px}.skeleton-line:last-child{width:60%}@keyframes loading{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}@media (max-width: 768px){.movers-container{grid-template-columns:1fr}.index-card{padding:12px;min-width:180px}.index-price{font-size:16px}.mover-name{max-width:150px}.market-indices-dynamic,.dynamic-movers{padding:16px}}body.dark-mode .market-indices-dynamic,body.dark-mode .dynamic-movers,body.dark-mode .dynamic-portfolios-summary,body.dark-mode .dynamic-market-news,body.dark-mode .dynamic-podcasts{--card-background: #1f2937;--background-secondary: #111827;--background-tertiary: #374151;--background-hover: #374151;--border-color: #374151;--text-primary: #f9fafb;--text-secondary: #9ca3af}body.dark-mode .mover-item,body.dark-mode .mover-card,body.dark-mode .index-card,body.dark-mode .portfolio-summary-card,body.dark-mode .news-card{background:#111827}body.dark-mode .mover-item:hover,body.dark-mode .mover-card:hover,body.dark-mode .portfolio-summary-card:hover{background:#374151}body.dark-mode .portfolio-summary-card.create-card{background:#111827;border-color:#374151}body.dark-mode .portfolio-summary-card.create-card:hover{background:#1f2937;border-color:#34c759}body.dark-mode .carousel-nav{background:#1f2937;border-color:#374151}body.dark-mode .carousel-nav:hover{background:#374151;border-color:#4b5563}body.dark-mode .movers-divider{background:linear-gradient(to bottom,transparent,#374151 20%,#374151 80%,transparent)}body.dark-mode .skeleton-line{background:linear-gradient(90deg,#374151 25%,#4b5563,#374151 75%)}.dynamic-market-news{background:var(--card-background, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:16px;margin:0}.dynamic-market-news.loading{opacity:.6}.market-news-carousel-wrapper{position:relative;display:flex;align-items:center;gap:12px;margin-bottom:12px}.market-news-carousel-container{display:flex;gap:16px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;padding:4px 0}.market-news-carousel-container::-webkit-scrollbar{display:none}.news-card{min-width:300px;max-width:300px;background:var(--background-secondary, #f9fafb);border-radius:8px;overflow:hidden;flex-shrink:0;transition:transform .2s,box-shadow .2s;cursor:pointer;text-decoration:none;color:inherit;display:flex;flex-direction:column}.news-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.news-card.skeleton{animation:pulse 1.5s ease-in-out infinite}.news-image-container{width:100%;height:160px;overflow:hidden;background:var(--background-tertiary, #e5e7eb);position:relative}.news-image-container.clickable{cursor:pointer}.news-video-player{width:100%;height:169px;border:none;border-radius:8px 8px 0 0}.news-image{width:100%;height:100%;object-fit:cover}.video-play-overlay{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);width:48px;height:48px;background:#000000b3;border-radius:50%;display:flex;align-items:center;justify-content:center;transition:all .2s}.news-card:hover .video-play-overlay{background:#ff0000e6;transform:translate(-50%,-50%) scale(1.1)}.play-icon{color:#fff;font-size:20px;margin-left:4px}.news-content{padding:12px;flex:1;display:flex;flex-direction:column}.news-title{font-size:14px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-description{font-size:12px;color:var(--text-secondary, #6b7280);line-height:1.5;margin:0 0 8px;flex:1}.news-meta{display:flex;justify-content:space-between;align-items:center;font-size:11px;color:var(--text-tertiary, #9ca3af);padding-top:8px;border-top:1px solid var(--border-color, #e5e7eb)}.news-publisher{font-weight:600;color:var(--text-secondary, #6b7280)}.news-time{color:var(--text-tertiary, #9ca3af)}.skeleton-image{width:100%;height:160px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite}.skeleton-content{padding:12px}.skeleton-line.short{width:40%}.dynamic-market-news-error,.dynamic-market-news-empty{display:flex;align-items:center;gap:8px;padding:16px;background:var(--background-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;color:var(--text-secondary, #6b7280);font-size:14px}.dynamic-podcasts{background:var(--card-background, #fff);border:1px solid var(--border-color, #e5e7eb);border-radius:12px;padding:16px;margin:0}.dynamic-podcasts.loading{opacity:.6}.podcasts-carousel-wrapper{position:relative;display:flex;align-items:center;gap:12px;margin-bottom:12px}.podcasts-carousel-container{display:flex;gap:16px;overflow-x:auto;scroll-behavior:smooth;-webkit-overflow-scrolling:touch;scrollbar-width:none;flex:1;padding:4px 0}.podcasts-carousel-container::-webkit-scrollbar{display:none}.podcast-card{min-width:280px;max-width:280px;background:var(--background-secondary, #f9fafb);border-radius:8px;padding:12px;flex-shrink:0;transition:transform .2s,box-shadow .2s;cursor:pointer;display:flex;flex-direction:column}.podcast-card:hover{transform:translateY(-2px);box-shadow:0 4px 12px #0000001a}.podcast-card.skeleton{animation:pulse 1.5s ease-in-out infinite}.podcast-header{display:flex;gap:10px;margin-bottom:10px;align-items:flex-start}.podcast-artwork{width:50px;height:50px;border-radius:6px;object-fit:cover;flex-shrink:0;background:var(--background-tertiary, #e5e7eb)}.podcast-info{flex:1;min-width:0}.podcast-name{font-size:11px;font-weight:600;color:var(--text-secondary, #6b7280);margin-bottom:4px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.podcast-date{font-size:10px;color:var(--text-tertiary, #9ca3af)}.podcast-title{font-size:13px;font-weight:600;color:var(--text-primary, #111827);margin:0 0 8px;line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.podcast-description{font-size:12px;color:var(--text-secondary, #6b7280);line-height:1.4;margin:0 0 10px;flex:1}.podcast-actions{display:flex;justify-content:flex-end}.podcast-actions.playing{justify-content:space-between;align-items:center}.podcast-player-container{display:flex;align-items:center;gap:8px;width:100%}.podcast-audio-player{width:100%;height:40px;outline:none;border-radius:8px;background:transparent}.podcast-audio-player::-webkit-media-controls-panel{background-color:#f3f4f6;border-radius:8px;padding:4px 8px}.podcast-audio-player::-webkit-media-controls-play-button{filter:invert(.2) brightness(.8);opacity:.9}.podcast-audio-player::-webkit-media-controls-mute-button{filter:invert(.2) brightness(.8);opacity:.9}.podcast-audio-player::-webkit-media-controls-timeline{background:#d1d5db;border-radius:4px;height:6px;margin:0 8px}.podcast-audio-player::-webkit-media-controls-timeline-container{display:flex;align-items:center}.podcast-audio-player::-webkit-media-controls-current-time-display,.podcast-audio-player::-webkit-media-controls-time-remaining-display{color:#4b5563;font-size:11px;font-weight:500}.podcast-audio-player::-webkit-media-controls-volume-slider{background:#d1d5db;border-radius:4px;height:6px}.podcast-audio-player::-webkit-media-controls-volume-slider-container{display:flex;align-items:center}.podcast-external-link{display:inline-flex;align-items:center;justify-content:center;padding:6px;color:var(--text-secondary, #6b7280);transition:color .2s;flex-shrink:0}.podcast-external-link:hover{color:var(--brand-primary, #3b82f6)}.podcast-link{display:inline-flex;align-items:center;padding:6px 12px;background:var(--brand-primary, #3b82f6);color:#fff;border:none;border-radius:6px;text-decoration:none;font-size:12px;font-weight:600;cursor:pointer;transition:background .2s}.podcast-link:hover{background:var(--brand-primary-dark, #2563eb)}.skeleton-artwork{width:50px;height:50px;border-radius:6px;background:linear-gradient(90deg,#f0f0f0 25%,#e0e0e0,#f0f0f0 75%);background-size:200% 100%;animation:loading 1.5s ease-in-out infinite;flex-shrink:0}.dynamic-podcasts-error,.dynamic-podcasts-empty{display:flex;align-items:center;gap:8px;padding:16px;background:var(--background-secondary, #f9fafb);border:1px solid var(--border-color, #e5e7eb);border-radius:8px;color:var(--text-secondary, #6b7280);font-size:14px}@media (max-width: 768px){.news-card{min-width:260px;max-width:260px}.podcast-card{min-width:240px;max-width:240px}.news-image-container{height:140px}.podcast-artwork{width:40px;height:40px}}body.dark-mode .news-image-container,body.dark-mode .podcast-artwork{background:#374151}body.dark-mode .skeleton-image,body.dark-mode .skeleton-artwork{background:linear-gradient(90deg,#374151 25%,#4b5563,#374151 75%)}body.dark-mode .podcast-audio-player{background:transparent}body.dark-mode .podcast-audio-player::-webkit-media-controls-panel{background-color:#1f2937;border-radius:8px;padding:4px 8px}body.dark-mode .podcast-audio-player::-webkit-media-controls-play-button{filter:invert(1) brightness(1.2);opacity:.95}body.dark-mode .podcast-audio-player::-webkit-media-controls-mute-button{filter:invert(1) brightness(1.2);opacity:.95}body.dark-mode .podcast-audio-player::-webkit-media-controls-timeline{background:#4b5563;border-radius:4px;height:6px;margin:0 8px}body.dark-mode .podcast-audio-player::-webkit-media-controls-current-time-display,body.dark-mode .podcast-audio-player::-webkit-media-controls-time-remaining-display{color:#d1d5db}body.dark-mode .podcast-audio-player::-webkit-media-controls-volume-slider{background:#4b5563;border-radius:4px;height:6px}body.dark-mode .podcast-external-link{color:#9ca3af}body.dark-mode .podcast-external-link:hover{color:#3b82f6}body:has(.public-artifact-view){overflow:auto!important;height:auto!important}html:has(.public-artifact-view){overflow:auto!important;height:auto!important}#root:has(.public-artifact-view){height:auto!important}.public-artifact-view{min-height:100vh;height:auto;background:var(--bg-secondary);padding:2rem 1rem;overflow-y:auto;overflow-x:hidden;color:var(--text-primary)}.public-artifact-container{max-width:900px;margin:0 auto}.public-artifact-view.loading{display:flex;align-items:center;justify-content:center;min-height:100vh;height:auto;color:var(--text-primary)}.loading-spinner{text-align:center;color:var(--text-primary)}.spinner{width:50px;height:50px;border:4px solid var(--border-primary);border-top-color:var(--primary-color);border-radius:50%;animation:spin 1s linear infinite;margin:0 auto 1rem}.public-artifact-view.error{display:flex;align-items:center;justify-content:center;min-height:100vh;height:auto;color:var(--text-primary)}.error-message{text-align:center;max-width:500px}.error-icon{font-size:3rem;margin-bottom:1rem;display:block;color:var(--text-primary)}.error-message h2{font-size:1.5rem;margin-bottom:.5rem;color:var(--text-primary)}.error-message p{color:var(--text-secondary);margin-bottom:2rem}.back-home-button{display:inline-block;padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;text-decoration:none;border-radius:8px;font-weight:500;transition:background .2s}.model-alpha-market-report{background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:12px;padding:2rem;margin-bottom:2rem;color:var(--text-primary)}.report-branding{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.report-branding-left{display:flex;align-items:center;gap:.5rem}.report-branding-logo{width:24px;height:24px;border-radius:4px}.report-branding-text{font-size:.75rem;font-weight:600;color:var(--text-secondary);letter-spacing:.05em;text-transform:uppercase}.report-branding-right{display:flex;align-items:center;gap:1rem}.report-signup-button-inline{padding:.375rem .875rem;font-size:.75rem;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border-primary);border-radius:6px;text-decoration:none;transition:all .2s ease;white-space:nowrap;opacity:.6}.report-signup-button-inline:hover{color:var(--text-primary);border-color:var(--text-secondary);opacity:1;background:var(--bg-secondary);transform:translateY(-1px)}.report-header{margin-bottom:2rem;padding-bottom:1.5rem;border-bottom:1px solid var(--border-primary)}.report-header-row{display:flex;align-items:flex-start;justify-content:space-between;gap:1rem;margin-bottom:1rem}.report-title{font-size:1.25rem;font-weight:600;color:var(--text-primary);margin:0;flex:1}.report-fear-gauge{flex-shrink:0}.report-meta-row{display:flex;align-items:center;justify-content:space-between;gap:1rem;flex-wrap:wrap}.report-timestamp{font-size:.875rem;color:var(--text-secondary);padding:.375rem .75rem;background:var(--bg-secondary);border-radius:6px;display:inline-flex;align-items:center;gap:.5rem}.report-timestamp.expired{color:var(--warning-text);background:var(--warning-bg)}.report-timestamp.fresh{color:var(--success-text);background:var(--success-bg)}.report-share-button{padding:.5rem 1rem;background:var(--primary-color);color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:500;cursor:pointer;transition:background .2s;display:inline-flex;align-items:center;gap:.5rem}.report-share-button:hover{background:var(--accent-hover)}.report-content{color:var(--text-primary);line-height:1.6;font-size:.9rem}.report-text-section{margin-bottom:1.5rem}.report-text-section h1,.report-text-section h2,.report-text-section h3{margin-top:1.5rem;margin-bottom:.75rem;color:var(--text-primary);font-weight:600}.report-text-section h1{font-size:1.5rem}.report-text-section h2{font-size:1.25rem}.report-text-section h3{font-size:1.1rem}.report-text-section p{margin-bottom:1rem;font-size:.9rem}.report-text-section ul,.report-text-section ol{margin:1rem 0;padding-left:2rem}.report-text-section li{margin-bottom:.5rem}.report-text-section strong{color:var(--text-primary);font-weight:600}.report-text-section code{background:var(--bg-secondary);padding:.125rem .375rem;border-radius:4px;font-size:.875em;font-family:Courier New,monospace}.report-component-section{margin:2rem 0}.report-disclaimer{margin-top:2.5rem;padding-top:1.5rem;border-top:1px solid var(--border-primary);font-size:.75rem;color:var(--text-tertiary);line-height:1.5;text-align:center;opacity:.7}.report-footer{margin-top:2rem;padding-top:2rem;border-top:1px solid var(--border-primary);display:flex;align-items:center;justify-content:space-between;gap:1.5rem;flex-wrap:wrap}.report-footer-branding{display:flex;align-items:center;gap:1rem}.report-footer-logo{width:48px;height:48px;border-radius:8px}.report-footer-text strong{display:block;font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.25rem}.report-footer-text p{font-size:.875rem;color:var(--text-secondary);margin:0}.report-footer-cta{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;text-decoration:none;border-radius:8px;font-weight:500;transition:background .2s;white-space:nowrap}.report-footer-cta:hover{background:var(--accent-hover)}@media (max-width: 768px){.public-artifact-view{padding:1rem .5rem}.model-alpha-market-report{padding:1.5rem 1rem;border-radius:0;border-left:none;border-right:none}.report-branding{flex-direction:column;align-items:flex-start;gap:1rem}.report-branding-right{width:100%;justify-content:space-between}.report-signup-button-inline{font-size:.7rem;padding:.3rem .75rem}.report-header-row{flex-direction:column;align-items:flex-start}.report-title{font-size:1.25rem}.report-meta-row{flex-direction:column;align-items:flex-start;gap:.75rem}.report-footer{flex-direction:column;align-items:flex-start}.report-footer-cta{width:100%;text-align:center}}.model-alpha-market-report.chat-view{background:transparent;border:none;border-radius:0;padding:0;margin:0}.model-alpha-market-report.chat-view .report-header{border-bottom:none;padding-bottom:0}.model-alpha-market-report.chat-view .report-footer{display:none}body:has(.public-model-view){overflow:auto!important;height:auto!important}.public-model-view{min-height:100vh;height:auto;background:var(--bg-secondary);padding:2rem 1rem;overflow-y:auto;overflow-x:hidden;color:var(--text-primary)}.public-model-container{max-width:900px;margin:0 auto;background:var(--bg-primary);border:1px solid var(--border-primary);border-radius:12px;overflow:visible}.public-model-header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 2rem;background:var(--bg-primary)}.header-branding{display:flex;align-items:center}.logo-link{display:flex;align-items:center;gap:.5rem;text-decoration:none;color:var(--text-secondary);font-weight:600;font-size:.75rem;letter-spacing:.05em;text-transform:uppercase;transition:color .2s}.logo-link:hover{color:var(--text-primary)}.logo-icon{width:24px;height:24px;border-radius:4px}.logo-text{font-size:.75rem;font-weight:600}.header-right{display:flex;flex-direction:column;align-items:flex-end;gap:8px}.header-stats{display:flex;gap:8px;font-size:.7rem;color:var(--text-secondary);opacity:.8}.header-stat-item{color:var(--text-secondary);white-space:nowrap}.header-stat-item:before{content:"•";margin:0 6px;color:var(--border-primary)}.header-stat-item:first-child:before{content:"";margin:0}.header-actions{display:flex;gap:12px;align-items:center}.sign-up-button,.dashboard-button{padding:.375rem .875rem;font-size:.75rem;font-weight:500;color:var(--text-secondary);background:transparent;border:1px solid var(--border-primary);border-radius:6px;text-decoration:none;transition:all .2s ease;white-space:nowrap;opacity:.6}.sign-up-button:hover,.dashboard-button:hover{color:var(--text-primary);border-color:var(--text-secondary);opacity:1;background:var(--bg-secondary);transform:translateY(-1px)}.header-clone-button{padding:.375rem .875rem;font-size:.75rem;font-weight:500;color:#fff;background:#10b981;border:1px solid #10b981;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap;height:100%}.header-clone-button:hover:not(:disabled){background:#059669;border-color:#059669;transform:translateY(-1px)}.header-clone-button:disabled{opacity:.6;cursor:not-allowed}.header-clone-success{padding:.375rem .875rem;font-size:.75rem;font-weight:500;color:#10b981;background:transparent;border:1px solid #10b981;border-radius:6px;white-space:nowrap}.public-model-content{padding:2rem}.model-header-section{margin-bottom:24px;margin-top:-20px}.model-title{font-size:1.5rem;font-weight:600;margin:0 0 .5rem;color:var(--text-primary);line-height:1.3}.badge{padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:500}.ai-badge{background:var(--primary-color);color:#fff}.clone-action-section{margin:2rem 0;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;text-align:center}.clone-button{padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border:none;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s,transform .2s;display:inline-flex;align-items:center;gap:.75rem}.clone-button:hover:not(:disabled){background:var(--accent-hover);transform:translateY(-1px)}.clone-button:disabled{opacity:.6;cursor:not-allowed}.clone-icon{font-size:20px}.spinner-small{display:inline-block;width:16px;height:16px;border:2px solid rgba(255,255,255,.3);border-top-color:#fff;border-radius:50%;animation:spin .6s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.clone-success-banner{display:flex;align-items:center;gap:16px;padding:16px;background:#d4edda;border:1px solid #c3e6cb;border-radius:8px;color:#155724}body.dark-mode .clone-success-banner{background:#1e4620;border-color:#2d5a2e;color:#a8d9aa}.success-icon{font-size:32px}.clone-error-message{margin-top:12px;padding:12px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;display:flex;align-items:center;gap:8px}body.dark-mode .clone-error-message{background:#4a2020;border-color:#5a2a2a;color:#e8a1a1}.auth-hint{margin-top:12px;color:#666;font-size:14px}body.dark-mode .auth-hint{color:#999}.clone-error-banner{margin:1.5rem 0;padding:12px 16px;background:#f8d7da;border:1px solid #f5c6cb;border-radius:8px;color:#721c24;display:flex;align-items:center;gap:8px;font-size:.875rem}body.dark-mode .clone-error-banner{background:#4a2020;border-color:#5a2a2a;color:#e8a1a1}.commentary-section{margin:2rem 0;padding:1.5rem;background:var(--bg-secondary);border-radius:12px;border-left:4px solid var(--primary-color)}.section-title{font-size:1.25rem;font-weight:600;margin:0 0 1rem;color:var(--text-primary)}.commentary-content{font-size:.9rem;line-height:1.6;color:var(--text-primary);white-space:pre-wrap}.holdings-section{margin:32px 0}.holdings-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem}.timeframe-selector{padding:.5rem .75rem;background:var(--bg-primary);border:0px solid var(--border-primary);border-radius:6px;color:var(--text-primary);font-size:.875rem;cursor:pointer;transition:all .2s}.timeframe-selector:hover{border-color:var(--primary-color)}.timeframe-selector:focus{outline:none;border-color:var(--primary-color)}.holdings-table-wrapper{overflow-x:auto;border-radius:12px;border:1px solid var(--border-primary);margin:1rem 0}.holdings-table{width:100%;border-collapse:collapse}.holdings-table thead{background:var(--bg-secondary)}.holdings-table th{padding:.75rem 1rem;text-align:left;font-weight:600;font-size:.875rem;color:var(--text-secondary);border-bottom:2px solid var(--border-primary)}.holdings-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-primary);font-size:.875rem;color:var(--text-primary)}.holdings-table th,.holdings-table .allocation-cell,.holdings-table .type-cell{color:var(--text-primary)!important;opacity:1!important;display:table-cell!important;visibility:visible!important}.holdings-table th{color:var(--text-secondary)!important}.holdings-table tbody tr:last-child td{border-bottom:none}.ticker-cell{font-weight:600;color:var(--primary-color)}.allocation-cell{font-weight:600}.holdings-summary{margin-top:.75rem;font-size:.875rem;color:var(--text-secondary);text-align:right}.performance-section{margin:32px 0}.timeframe-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:16px;margin:16px 0}.timeframe-card{padding:20px;background:#f8f9fa;border-radius:12px;border:1px solid #e0e0e0}body.dark-mode .timeframe-card{background:#2a2a2a;border-color:#3a3a3a}.timeframe-label{font-size:16px;font-weight:600;margin:0 0 12px;color:#667eea}body.dark-mode .timeframe-label{color:#8b9ff5}.timeframe-stats{display:flex;flex-direction:column;gap:8px}.stat-row{display:flex;justify-content:space-between;align-items:center;font-size:14px}.stat-label{color:#666}body.dark-mode .stat-label{color:#999}.stat-value{font-weight:600;font-size:16px}.stat-value.positive{color:#10b981}.stat-value.negative{color:#ef4444}.performance-note{margin-top:12px;font-size:14px;color:#666;font-style:italic}body.dark-mode .performance-note{color:#999}.no-data-message{padding:40px;text-align:center;color:#999;font-style:italic}.disclaimer-section{margin:2rem 0;padding:1.25rem;background:var(--warning-bg);border-radius:12px;border:1px solid rgba(245,158,11,.3)}.disclaimer-text{font-size:.75rem;color:var(--text-tertiary);margin:0;line-height:1.5;opacity:.7}.public-model-footer{padding:1.5rem 2rem;border-top:1px solid var(--border-primary);text-align:center;color:var(--text-secondary);font-size:.875rem}.footer-link{color:var(--primary-color);text-decoration:none;font-weight:500;transition:color .2s}.footer-link:hover{color:var(--accent-hover)}.public-model-view.loading,.public-model-view.error{display:flex;align-items:center;justify-content:center;min-height:100vh}.loading-spinner,.error-message{text-align:center;padding:2.5rem;color:var(--text-primary)}.spinner{width:50px;height:50px;margin:0 auto 1.25rem;border:4px solid var(--border-primary);border-top-color:var(--primary-color);border-radius:50%;animation:spin .8s linear infinite}.error-icon{font-size:64px;display:block;margin-bottom:20px}.error-message h2{margin:0 0 .75rem;font-size:1.5rem;color:var(--text-primary)}.error-message p{margin:0 0 1.5rem;color:var(--text-secondary);font-size:1rem}.back-home-button{display:inline-block;padding:.75rem 1.5rem;background:var(--primary-color);color:#fff;border-radius:8px;text-decoration:none;font-weight:500;transition:background .2s}.back-home-button:hover{background:var(--accent-hover)}@media (max-width: 768px){.public-model-view{padding:0}.public-model-container{border-radius:0;min-height:100vh}.public-model-header{padding:16px 20px}.logo-text{font-size:20px}.public-model-content{padding:24px 20px}.model-title{font-size:24px}.model-metadata{flex-direction:column;align-items:flex-start}.clone-button{width:100%;justify-content:center}.timeframe-cards{grid-template-columns:1fr}.holdings-table{font-size:13px}.holdings-table th,.holdings-table td{padding:8px 12px}}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#f5f5f5}
