:root{--primary-color: #1a365d;--secondary-color: #2c7a7b;--accent-color: #ecc94b;--background-dark: #171923;--background-light: #f7fafc;--text-dark: #2d3748;--text-light: #e2e8f0;--success-color: #48bb78;--warning-color: #ed8936;--danger-color: #e53e3e;--card-bg-dark: #2d3748;--card-bg-light: #ffffff;--border-dark: #4a5568;--border-light: #e2e8f0;--shadow-dark: rgba(0, 0, 0, .3);--shadow-light: rgba(0, 0, 0, .1);--transition-speed: .3s}.app.dark{--background: var(--background-dark);--text-color: var(--text-light);--card-bg: var(--card-bg-dark);--border-color: var(--border-dark);--shadow: var(--shadow-dark)}.app.light{--background: var(--background-light);--text-color: var(--text-dark);--card-bg: var(--card-bg-light);--border-color: var(--border-light);--shadow: var(--shadow-light)}body{margin:0;font-family:Inter,-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;transition:background-color var(--transition-speed)}.app{background-color:var(--background);color:var(--text-color);min-height:100vh;transition:background-color var(--transition-speed),color var(--transition-speed)}::-webkit-scrollbar{width:8px;background:var(--background-color)}::-webkit-scrollbar-thumb{background:#232946;border-radius:8px}.layout{display:flex;min-height:100vh}.main-content{flex:1;display:flex;flex-direction:column;overflow-x:hidden}.content-area{flex:1;padding:20px;overflow-y:auto}.sidebar{width:250px;background-color:var(--background-color);color:var(--text-light);display:flex;flex-direction:column;transition:width var(--transition-speed);z-index:10}.sidebar.collapsed{width:70px}.logo-container{padding:20px;display:flex;align-items:center;justify-content:space-between;border-bottom:1px solid rgba(255,255,255,.1)}.logo{margin:0;font-size:1.5rem;font-weight:700}.logo-small{margin:0;font-size:1.2rem;font-weight:700}.collapse-btn{background:none;border:none;color:var(--text-light);cursor:pointer;font-size:1.2rem}.nav-menu{flex:1;padding:20px 0}.nav-menu ul{list-style:none;padding:0;margin:0}.nav-link{display:flex;align-items:center;padding:12px 20px;color:var(--subtitle-color);text-decoration:none;transition:background-color .2s}.nav-link:hover{box-shadow:0 8px 32px #6366f11f;border-color:#a5b4fc;text-decoration-color:#fff}.nav-link .icon{margin-right:15px;font-size:1.2rem}.sidebar-footer{padding:20px;border-top:1px solid rgba(255,255,255,.1)}.theme-toggle{width:100%;padding:10px;background:#ffffff1a;border:none;border-radius:4px;color:var(--text-light);cursor:pointer;display:flex;align-items:center;justify-content:center}.theme-toggle span{margin-left:10px}.app-header{background-color:var(--card-bg);border-bottom:1px solid var(--border-color);padding:15px 20px;box-shadow:0 2px 5px var(--shadow)}.page-title h1{margin:0;font-size:1.5rem;font-weight:600}.search-container{flex:0 1 400px}.search-container form{display:flex}.search-input{flex:1;padding:10px 15px;border:1px solid var(--border-color);border-radius:4px 0 0 4px;background-color:var(--background);color:var(--text-dark)}.search-button{padding:10px 15px;border:1.5px solid var(--border-color);border-radius:0 4px 4px 0;cursor:pointer}.user-actions{display:flex;align-items:center}.upload-btn{padding:10px 15px;background-color:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.upload-container{max-width:1200px;margin:0 auto;padding:40px 20px}.upload-header{text-align:center;margin-bottom:40px}.upload-header h1{font-size:2.5rem;margin-bottom:10px;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.upload-header p{font-size:1.2rem;color:var(--text-color);opacity:.8}.upload-area{border:2px dashed var(--border-color);border-radius:10px;padding:40px;text-align:center;background-color:var(--card-bg);transition:all .3s;margin-bottom:20px}.upload-area.drag-active{border-color:var(--secondary-color);background-color:#2c7a7b1a}.upload-area.upload-error{border-color:var(--danger-color);background-color:#e53e3e1a}.upload-icon{font-size:3rem;color:var(--secondary-color);margin-bottom:20px}.upload-area h3{font-size:1.5rem;margin-bottom:10px}.file-input-label{display:inline-block;padding:10px 20px;background-color:var(--secondary-color);color:#fff;border-radius:4px;cursor:pointer;margin:10px 0;font-weight:500}.file-input{display:none}.file-types{font-size:.9rem;color:var(--text-color);opacity:.7;margin-top:10px}.upload-progress{width:100%}.progress-bar-container{width:100%;height:10px;background-color:var(--border-color);border-radius:5px;margin:20px 0;overflow:hidden}.progress-bar{height:100%;background-color:var(--secondary-color);border-radius:5px;transition:width .3s}.upload-status-message{margin-top:10px;font-style:italic}.upload-success,.upload-error-message{text-align:center}.success-icon,.error-icon{font-size:3rem;margin-bottom:10px}.success-icon{color:var(--success-color)}.error-icon{color:var(--danger-color)}.retry-button{padding:10px 20px;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;margin-top:10px}.selected-file{background-color:var(--card-bg);padding:15px;border-radius:5px;margin-bottom:20px;display:flex;justify-content:space-between;align-items:center}.upload-button{padding:10px 20px;background-color:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500}.demo-option{text-align:center;margin:30px 0}.demo-button{padding:10px 20px;background-color:var(--primary-color);color:#fff;border:none;border-radius:4px;cursor:pointer;font-weight:500;margin-top:10px}.upload-features{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px;margin-top:40px}.feature{background-color:var(--card-bg);padding:20px;border-radius:8px;text-align:center;box-shadow:0 4px 6px var(--shadow);transition:transform .3s}.feature:hover{transform:translateY(-5px)}.feature-icon{font-size:2.5rem;margin-bottom:15px}.feature h3{margin-bottom:10px;color:var(--secondary-color)}.dashboard-container{max-width:1600px;margin:0 auto;padding:20px}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:20px}.portfolio-summary{display:flex;flex-direction:column}.portfolio-value{display:flex;align-items:center;margin-top:5px}.value-label{font-size:1rem;margin-right:10px}.value-amount{font-size:1.5rem;font-weight:600;margin-right:10px}.value-change{font-size:1rem;font-weight:500;padding:3px 8px;border-radius:4px}.time-range-selector{display:flex;background-color:var(--card-bg);border-radius:4px;overflow:hidden;box-shadow:0 2px 4px var(--shadow)}.time-range-selector button{padding:8px 15px;background:none;border:none;color:var(--text-color);cursor:pointer;transition:background-color .2s}.time-range-selector button.active{background-color:var(--secondary-color);color:#fff}.dashboard-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}.grid-item{background-color:var(--card-bg);border-radius:8px;padding:20px;box-shadow:0 4px 6px var(--shadow);grid-column:span 6}.grid-item h2{margin-top:0;margin-bottom:15px;font-size:1.2rem;color:var(--text-color);border-bottom:1px solid var(--border-color);padding-bottom:10px}.full-width{grid-column:span 12}.prediction-banner-container{grid-column:span 12;margin-bottom:20px}.performance-metrics-container{margin-left:80px;grid-column:span 1}.risk-metrics-container{margin-left:55%;grid-column:span 8}.sector-allocation-container{margin-left:30px;grid-column:span 7}.top-performers-container{margin-left:10%;grid-column:span 6}.worst-performers-container{margin-left:10%;margin-right:3%;grid-column:span 7}.holdings-container{grid-column:span 7;margin-left:3%}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(150px,1fr));gap:15px}.performers-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(200px,1fr));gap:15px}.holdings-table{width:100%;border-collapse:collapse}.holdings-table th,.holdings-table td{padding:10px;text-align:left;border-bottom:1px solid var(--border-color)}.holdings-table th{background-color:#0000000d;font-weight:600}.holdings-table tr:hover{background-color:#00000008}.symbol-cell{font-weight:600}.positive{color:var(--success-color)}.negative{color:var(--danger-color)}.neutral{color:var(--warning-color)}.loading-container,.no-data-container{display:flex;flex-direction:column;align-items:center;justify-content:center;height:70vh;text-align:center}.loading-spinner{border:4px solid rgba(0,0,0,.1);border-radius:50%;border-top:4px solid var(--secondary-color);width:40px;height:40px;animation:spin 1s linear infinite;margin-bottom:20px}.no-data-container button{margin-top:20px;padding:10px 20px;background-color:var(--secondary-color);color:#fff;border:none;border-radius:4px;cursor:pointer}.stock-card{background-color:var(--card-bg);border-radius:6px;padding:15px;display:flex;justify-content:space-between;box-shadow:0 2px 4px var(--shadow);transition:transform .2s}.stock-card:hover{transform:translateY(-3px)}.stock-info{display:flex;flex-direction:column}.stock-symbol{font-weight:600;font-size:1.1rem}.stock-name{font-size:.9rem;opacity:.8;margin-top:5px}.stock-metrics{display:flex;flex-direction:column;align-items:flex-end}.stock-value{font-weight:600}.stock-change{margin-top:5px;padding:2px 6px;border-radius:4px;font-size:.9rem}.performance-card,.risk-metrics-card{background-color:var(--card-bg);border-radius:6px;padding:15px;text-align:center;box-shadow:0 2px 4px var(--shadow)}.card-title{font-size:.9rem;opacity:.8;margin-bottom:10px}.card-value{font-size:1.5rem;font-weight:600;display:flex;align-items:center;justify-content:center}.trend-icon{margin-left:5px;font-size:1rem}.trend-icon.up{color:var(--success-color)}.trend-icon.down{color:var(--danger-color)}.card-description{font-size:.8rem;opacity:.7;margin-top:10px}.prediction-banner{background:linear-gradient(135deg,var(--primary-color),var(--secondary-color));border-radius:10px;padding:20px;color:#fff;box-shadow:0 4px 10px #0003}.prediction-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:15px}.prediction-header h2{margin:0;font-size:1.5rem;border-bottom:none;padding-bottom:0;color:#fff}.confidence-badge{background-color:#fff3;padding:5px 10px;border-radius:20px;font-size:.9rem;font-weight:500}.prediction-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(180px,1fr));gap:15px;margin-bottom:15px}.prediction-item{background-color:#ffffff1a;border-radius:8px;padding:15px;text-align:center}.prediction-item h3{margin-top:0;margin-bottom:10px;font-size:1rem;opacity:.9}.prediction-value{font-size:1.5rem;font-weight:600;margin-bottom:5px}.prediction-value.positive{color:#4ade80}.prediction-value.negative{color:#f87171}.prediction-value.neutral{color:#fbbf24}.prediction-value.highlight{color:#60a5fa}.prediction-value.warning{color:#f97316}.prediction-item p{margin:0;font-size:.8rem;opacity:.8}.prediction-footer{display:flex;flex-direction:column;align-items:center}.view-details-button{background-color:#fff3;color:#fff;border:none;border-radius:4px;padding:8px 15px;cursor:pointer;font-weight:500;transition:background-color .2s}.view-details-button:hover{background-color:#ffffff4d}.prediction-disclaimer{font-size:.8rem;opacity:.7;margin-top:10px;text-align:center}.predictive-analysis-container{max-width:1600px;margin:0 auto;padding:20px}.predictive-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.predictive-header h1{margin:0;font-size:1.8rem;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.time-horizon-selector{display:flex;background-color:var(--card-bg);border-radius:4px;overflow:hidden;box-shadow:0 2px 4px var(--shadow)}.time-horizon-selector button{padding:8px 15px;background:none;border:none;color:var(--text-color);cursor:pointer;transition:background-color .2s}.time-horizon-selector button.active{background-color:var(--secondary-color);color:#fff}.predictive-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}.prediction-chart-container{grid-column:span 12}.scenario-selector{display:flex;margin-bottom:15px}.scenario-selector button{padding:6px 12px;background:none;border:1px solid var(--border-color);color:var(--text-color);cursor:pointer;transition:all .2s}.scenario-selector button:first-child{border-radius:4px 0 0 4px}.scenario-selector button:last-child{border-radius:0 4px 4px 0}.scenario-selector button.active{background-color:var(--secondary-color);color:#fff;border-color:var(--secondary-color)}.scenario-metrics-container,.risk-metrics-container{grid-column:span 6}.scenario-cards{display:grid;grid-template-columns:repeat(3,1fr);gap:15px}.scenario-card{background-color:var(--card-bg);border-radius:8px;padding:15px;text-align:center;box-shadow:0 2px 4px var(--shadow);border-top:4px solid}.scenario-card.base{border-top-color:#8884d8}.scenario-card.bull{border-top-color:#82ca9d}.scenario-card.bear{border-top-color:#ff8042}.scenario-card h3{margin-top:0;margin-bottom:10px;font-size:1.1rem}.scenario-value{font-size:1.8rem;font-weight:600;margin-bottom:5px}.scenario-probability{font-size:.9rem;opacity:.8;margin-bottom:10px}.risk-metrics-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.risk-metric-card{background-color:var(--card-bg);border-radius:8px;padding:15px;text-align:center;box-shadow:0 2px 4px var(--shadow)}.risk-metric-card h3{margin-top:0;margin-bottom:10px;font-size:1rem}.metric-value{font-size:1.5rem;font-weight:600;margin-bottom:5px}.optimization-container{grid-column:span 12}.optimization-suggestions{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:15px}.suggestion-card{background-color:var(--card-bg);border-radius:8px;padding:15px;box-shadow:0 2px 4px var(--shadow);border-left:4px solid var(--secondary-color)}.suggestion-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:10px}.suggestion-header h3{margin:0;font-size:1.1rem}.confidence-badge{background-color:#2c7a7b1a;color:var(--secondary-color);padding:3px 8px;border-radius:20px;font-size:.8rem}.suggestion-description{margin-bottom:10px}.suggestion-impact{font-size:.9rem;opacity:.8}.market-research-container{max-width:1600px;margin:0 auto;padding:20px}.market-research-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:30px}.market-research-header h1{margin:0;font-size:1.8rem;background:linear-gradient(90deg,var(--primary-color),var(--secondary-color));-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.market-research-grid{display:grid;grid-template-columns:repeat(12,1fr);gap:20px}.market-sentiment-container{grid-column:span 6}.sentiment-overview{display:flex;gap:20px}.sentiment-gauge{position:relative;width:120px;height:120px;border-radius:50%;background-color:var(--card-bg);overflow:hidden;display:flex;align-items:center;justify-content:center}.gauge-value{position:absolute;top:0;left:0;width:50%;height:100%;background-color:var(--secondary-color);transform-origin:right center}.gauge-label{position:relative;z-index:1;font-weight:600;font-size:1.1rem;background-color:var(--card-bg);padding:5px 10px;border-radius:20px}.sentiment-topics{flex:1}.sentiment-topics h3{margin-top:0;margin-bottom:15px;font-size:1.1rem}.topics-list{display:flex;flex-direction:column;gap:10px}.topic-item{display:flex;align-items:center;gap:10px}.topic-name{width:120px;font-size:.9rem}.sentiment-bar-container{flex:1;height:8px;background-color:var(--border-color);border-radius:4px;overflow:hidden}.sentiment-bar{height:100%;background-color:var(--secondary-color)}.sentiment-value{width:70px;font-size:.8rem;text-align:right}.economic-indicators-container{grid-column:span 6}.indicators-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:15px}.indicator-card{background-color:var(--card-bg);border-radius:8px;padding:15px;box-shadow:0 2px 4px var(--shadow)}.indicator-card h3{margin-top:0;margin-bottom:10px;font-size:1rem}.indicator-value{font-size:1.5rem;font-weight:600;display:flex;align-items:center;margin-bottom:5px}.trend-arrow{margin-left:5px;font-size:1rem}.trend-arrow.up{color:var(--success-color)}.trend-arrow.down{color:var(--danger-color)}.indicator-previous{font-size:.9rem;opacity:.8;margin-bottom:10px}.indicator-impact{font-size:.8rem;margin:0}.sector-performance-container,.sector-detail-container{grid-column:span 6}.sector-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.metric-item{display:flex;flex-direction:column}.metric-label{font-size:.8rem;opacity:.8}.sector-chart{margin-bottom:20px}.sector-chart h3,.sector-top-performers h3{margin-top:0;margin-bottom:10px;font-size:1.1rem}.performers-list{display:flex;flex-direction:column;gap:10px}.performer-item{display:flex;align-items:center;background-color:#00000008;padding:8px 10px;border-radius:4px}.performer-symbol{font-weight:600;width:60px}.performer-name{flex:1;font-size:.9rem}.performer-return{font-weight:500}.top-stocks-container{grid-column:span 6}.stocks-list{display:flex;flex-direction:column;gap:10px}.stock-item{display:flex;align-items:center;background-color:#00000008;padding:10px;border-radius:4px;cursor:pointer;transition:background-color .2s}.stock-item:hover,.stock-item.selected{background-color:#2c7a7b1a}.stock-item.selected{border-left:3px solid var(--secondary-color)}.stock-detail-container{grid-column:span 6}.stock-metrics{display:grid;grid-template-columns:repeat(3,1fr);gap:10px;margin-bottom:20px}.stock-chart{margin-bottom:20px}.stock-chart h3,.stock-news h3{margin-top:0;margin-bottom:10px;font-size:1.1rem}.news-list{display:flex;flex-direction:column;gap:10px}.news-item{display:flex;align-items:center;background-color:#00000008;padding:10px;border-radius:4px}.sentiment-indicator{width:8px;height:40px;border-radius:4px;margin-right:10px}.sentiment-indicator.positive{background-color:var(--success-color)}.sentiment-indicator.neutral{background-color:var(--warning-color)}.sentiment-indicator.negative{background-color:var(--danger-color)}.news-content{flex:1}.news-headline{font-weight:500;margin-bottom:5px}.news-meta{display:flex;justify-content:space-between;font-size:.8rem;opacity:.8}.ai-insights-container{grid-column:span 12}.insights-content{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:20px}.insight-card{background-color:var(--card-bg);border-radius:8px;padding:20px;box-shadow:0 2px 4px var(--shadow);border-top:4px solid var(--secondary-color)}.insight-card h3{margin-top:0;margin-bottom:15px;font-size:1.2rem;color:var(--secondary-color)}@media (max-width: 1200px){.dashboard-grid,.predictive-grid,.market-research-grid{grid-template-columns:repeat(6,1fr)}.performance-chart-container,.sector-allocation-container,.performance-metrics-container,.risk-metrics-container,.risk-return-container,.top-performers-container,.worst-performers-container,.holdings-container,.prediction-chart-container,.scenario-metrics-container,.optimization-container,.market-sentiment-container,.economic-indicators-container,.sector-performance-container,.sector-detail-container,.top-stocks-container,.stock-detail-container,.ai-insights-container,.full-width{grid-column:span 8}}@media (max-width: 768px){.dashboard-grid,.predictive-grid,.market-research-grid{grid-template-columns:1fr}.performance-chart-container,.sector-allocation-container,.performance-metrics-container,.risk-metrics-container,.risk-return-container,.top-performers-container,.worst-performers-container,.holdings-container,.prediction-chart-container,.scenario-metrics-container,.optimization-container,.market-sentiment-container,.economic-indicators-container,.sector-performance-container,.sector-detail-container,.top-stocks-container,.stock-detail-container,.ai-insights-container,.full-width{grid-column:span 1}.dashboard-header,.predictive-header,.market-research-header{flex-direction:column;align-items:flex-start;gap:15px}.time-range-selector,.time-horizon-selector{width:100%;justify-content:space-between}.scenario-cards{grid-template-columns:1fr}.header-content{flex-direction:column;gap:15px}.search-container{width:100%}.sidebar{width:70px}.sidebar:not(.collapsed){position:absolute;height:100%;z-index:100}}.dark .recharts-cartesian-grid-horizontal line,.dark .recharts-cartesian-grid-vertical line{stroke:#ffffff1a}.dark .recharts-text{fill:var(--text-light)}.dark .recharts-default-tooltip{background-color:#000c!important;border-color:var(--border-dark)!important}.dark .recharts-tooltip-label,.dark .recharts-tooltip-item{color:var(--text-light)!important}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}.fade-in{animation:fadeIn .5s ease-in-out}.slide-up{animation:slideUp .5s ease-in-out}.highlight{color:var(--accent-color)}.warning{color:var(--warning-color)}.text-center{text-align:center}.mt-1{margin-top:.25rem}.mt-2{margin-top:.5rem}.mt-3{margin-top:.75rem}.mt-4{margin-top:1rem}.mt-5{margin-top:1.25rem}.mb-1{margin-bottom:.25rem}.mb-2{margin-bottom:.5rem}.mb-3{margin-bottom:.75rem}.mb-4{margin-bottom:1rem}.mb-5{margin-bottom:1.25rem}.app-header{background:var(--card-background-color);color:var(--text-color);border-bottom:1.5px solid var(--border-color);box-shadow:0 4px 24px #6366f114;padding:1.2rem 2.5rem;position:sticky;top:0;z-index:100}.header-content{display:flex;align-items:center;justify-content:space-between}.page-title h1{font-size:1.7rem;font-weight:700;color:var(--subtitle-color);letter-spacing:.01em;margin:0}.search-container{flex:auto;display:block;align-items:center;background:#282c40d9;color:var(--text-color);border-radius:999px;padding:.2rem 1rem;box-shadow:0 2px 8px #6366f10f;border:1.5px solid rgba(180,180,255,.12)}.search-input{border:none;color:var(--text-color);background:transparent;outline:none;font-size:1rem;padding:.5rem .7rem;font-family:inherit;width:180px}.search-input::placeholder{color:#a5b4fc}.search-button{background:var(--accent-gradient);color:#fff;border:none;border-radius:999px;padding:.5em 1.3em;font-size:1rem;font-weight:600;cursor:pointer;margin-left:8px;box-shadow:0 2px 8px #6366f11a;transition:background .2s,box-shadow .2s}.search-button:hover{background:linear-gradient(90deg,#a5b4fc,#6366f1);box-shadow:0 4px 16px #6366f12e}.user-actions{display:flex;align-items:center;gap:10px}.upload-btn{background-color:var(--button-background-color);color:#fff;border:none;padding:8px 12px;border-radius:4px;cursor:pointer}.upload-btn:hover{background-color:var(--button-hover-color)}.theme-toggle-btn{background-color:var(--card-background-color);color:var(--text-color);border:1px solid var(--border-color);padding:8px 12px;border-radius:4px;cursor:pointer}.theme-toggle-btn:hover{background-color:var(--border-color)}.search-image-icon{height:32px;width:32px;display:flex;align-items:center;justify-content:center;transition:background .2s;border-radius:50%}.search-image-icon:hover{background:#6366f11f}.search-loader-overlay{position:fixed;z-index:9999;top:0;right:0;bottom:0;left:0;background:#141622e0;display:flex;flex-direction:column;align-items:center;justify-content:center}.search-loader-spinner{border:6px solid #232946;border-top:6px solid #6366f1;border-radius:50%;width:54px;height:54px;animation:spin 1s linear infinite;margin-bottom:1.2rem}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.search-loader-text{color:var(--subtitle-color);font-size:1.2rem;font-weight:600;text-align:center;margin-bottom:.5rem}.search-loader-subtext{color:#b3b8c5;font-size:1rem;margin-top:.2rem;text-align:center}.logout-container{display:flex;align-items:center;justify-content:flex-end;margin-left:auto}.logout-button{background:linear-gradient(90deg,#23272f,#2d313a);color:#fff;border:none;border-radius:22px;padding:8px 22px;font-size:1rem;font-weight:500;cursor:pointer;transition:background .2s,box-shadow .2s,opacity .2s;box-shadow:0 2px 8px #0000002e;outline:none}.logout-button:disabled{opacity:.6;cursor:not-allowed;background:#23272f}.logout-button:hover:not(:disabled){background:linear-gradient(90deg,#2d313a,#23272f);box-shadow:0 4px 16px #00000038}.prediction-banner{background:var(--card-background-color);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:24px;box-shadow:0 8px 32px #1f26872e;padding:2rem 2.5rem;margin:2rem auto;max-width:700px;font-family:Inter,Segoe UI,Arial,sans-serif;border:1.5px solid var(--border-color);transition:box-shadow .2s;color:var(--text-color)}.prediction-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.prediction-header h2{font-size:1.5rem;font-weight:700;color:var(--text-color);letter-spacing:.01em}.confidence-badge{background:var(--accent-gradient);color:#fff;font-weight:600;padding:.4em 1.1em;border-radius:999px;font-size:1rem;box-shadow:0 2px 8px #6366f114}.prediction-content{display:flex;flex-wrap:wrap;gap:2rem;justify-content:space-between;margin-bottom:1.5rem}.prediction-item{flex:1 1 160px;min-width:150px;background:#282c40d9;color:var(--text-color);border-radius:16px;padding:1.2rem 1rem;box-shadow:0 2px 8px #6366f10f;display:flex;flex-direction:column;align-items:center;margin-bottom:.5rem;transition:background .2s}.prediction-item h3{font-size:1.1rem;font-weight:600;color:var(--subtitle-color);margin-bottom:.5rem}.prediction-value{font-size:1.6rem;font-weight:700;margin-bottom:.3rem;letter-spacing:.01em}.prediction-value.positive{color:var(--positive-color)}.prediction-value.neutral{color:var(--subtitle-color)}.prediction-value.highlight{color:#f59e42}.prediction-value.warning{color:var(--negative-color)}.prediction-footer{display:flex;flex-direction:column;align-items:flex-start;margin-top:1.5rem;color:var(--text-color)}.view-details-button{background:var(--accent-gradient);color:#fff;border:none;border-radius:999px;padding:.7em 1.8em;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:.7rem;box-shadow:0 2px 8px #6366f11a;transition:background .2s,box-shadow .2s}.view-details-button:hover{background:linear-gradient(90deg,#a5b4fc,#6366f1);box-shadow:0 4px 16px #6366f12e}.prediction-disclaimer{font-size:.95rem;color:#b3b8c5;margin-top:.2rem;opacity:.85}.performance-metrics-container{display:flex;justify-content:space-around;gap:24px;width:100%;min-height:180px;padding:0 24px 24px;box-sizing:border-box;align-items:center;align-content:space-around;flex-direction:row}.performance-card{background:var(--card-background-color);color:var(--text-color);border:1.5px solid var(--border-color);backdrop-filter:blur(16px) saturate(180%);-webkit-backdrop-filter:blur(16px) saturate(180%);border-radius:18px;box-shadow:0 8px 32px #6366f11a;padding:22px 18px;display:flex;flex-direction:column;align-items:center;flex:1 1 0;min-width:0;max-width:220px;box-sizing:border-box;margin:0 8px;transition:box-shadow .2s,border .2s}.performance-card:hover{box-shadow:0 12px 40px #6366f12e;border-color:#a5b4fc}.card-title{font-size:1.08rem;color:var(--subtitle-color);margin-bottom:8px;font-weight:600;text-align:center;letter-spacing:.01em}.card-value{font-size:1.6rem;font-weight:700;display:flex;align-items:center;justify-content:center;margin-bottom:4px;letter-spacing:.01em}.card-value.positive{color:var(--positive-color)}.card-value.negative{color:var(--negative-color)}.card-value.neutral{color:var(--subtitle-color)}.trend-icon{margin-left:6px;font-size:1.1rem;vertical-align:middle}@media (max-width: 900px){.performance-metrics-container{flex-direction:column;gap:16px;padding:0 8px 16px}.performance-card{width:100%;max-width:none;margin:8px 0}}[data-theme=dark]{--background-color: #181a20;--card-background-color: rgba(30, 34, 54, .85);--text-color: #f4f6f9;--subtitle-color: #a5b4fc;--border-color: rgba(99, 102, 241, .18);--positive-color: #32cd32;--negative-color: #ff6347}.dashboard-container{background:var(--background-color);color:var(--text-color);padding:32px 0;min-height:100vh;font-family:Inter,Segoe UI,Arial,sans-serif}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:32px}.portfolio-summary h1{font-size:2.2rem;font-weight:700;color:var(--text-color);letter-spacing:.01em}.portfolio-value{font-size:1.2rem;color:var(--text-color)}.portfolio-value .value-label{font-weight:500}.portfolio-value .value-amount{font-weight:700}.portfolio-value .value-change{font-weight:600;margin-left:10px}.portfolio-value .value-change.positive{color:var(--positive-color)}.portfolio-value .value-change.negative{color:var(--negative-color)}.time-range-selector button{background:var(--card-background-color);color:var(--text-color);border:1.5px solid var(--border-color);padding:8px 16px;border-radius:999px;cursor:pointer;margin-right:8px;font-weight:600;transition:background .2s,color .2s}.time-range-selector button.active{background:var(--accent-gradient);color:#fff}.time-range-selector button:hover{background:var(--subtitle-color);color:#fff}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(340px,1fr));gap:32px;width:100%;max-width:1400px;margin:0 auto;box-sizing:border-box}.grid-item,.performance-metrics-container,.risk-metrics-container,.sector-allocation-container,.top-performers-container,.worst-performers-container,.holdings-container{background:var(--card-background-color);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:24px;border:1.5px solid var(--border-color);box-shadow:0 8px 32px #1f26872e;padding:2rem 1.5rem;transition:box-shadow .2s;color:var(--text-color);overflow-x:auto;min-width:0;max-width:100%;box-sizing:border-box}.grid-item h2,.performance-metrics-container h2,.risk-metrics-container h2,.sector-allocation-container h2,.top-performers-container h2,.worst-performers-container h2,.holdings-container h2{font-size:1.4rem;font-weight:700;color:var(--subtitle-color);margin-bottom:18px;letter-spacing:.01em}.performance-metrics-container{background:var(--card-background-color);-webkit-backdrop-filter:var(--card-blur);backdrop-filter:var(--card-blur);border-radius:24px;border:1.5px solid var(--border-color);box-shadow:0 8px 32px #1f26872e;padding:2rem 1.5rem;color:var(--text-color);display:flex;flex-direction:column;align-items:center}.performance-metrics-container h2{color:var(--subtitle-color);font-size:1.4rem;font-weight:700;margin-bottom:24px;letter-spacing:.01em;border-bottom:1px solid var(--border-color);width:100%;padding-bottom:8px;text-align:left}.metrics-grid{width:100%;display:flex;flex-direction:column;gap:32px}.performance-metric-block{display:flex;flex-direction:column;align-items:center;margin-bottom:0}.performance-metric-title{color:var(--subtitle-color);font-size:1.1rem;font-weight:600;margin-bottom:6px}.performance-metric-value{font-size:2rem;font-weight:700;margin-bottom:4px;letter-spacing:.01em}.performance-metric-value.positive{color:var(--positive-color)}.performance-metric-value.negative{color:var(--negative-color)}.performance-metric-value.neutral{color:var(--subtitle-color)}.performance-metric-trend{font-size:1rem;color:var(--subtitle-color);opacity:.7;margin-top:2px}@media (max-width: 900px){.dashboard-grid{grid-template-columns:1fr;gap:16px;padding:0 8px}.grid-item,.performance-metrics-container,.risk-metrics-container,.sector-allocation-container,.top-performers-container,.worst-performers-container,.holdings-container{padding:1.2rem .7rem}}.holdings-table-container{width:100%;overflow-x:auto}.holdings-table{width:100%;border-collapse:collapse;background:transparent;min-width:600px}.holdings-table th,.holdings-table td{border:1px solid var(--border-color);padding:12px;text-align:left;background:transparent;color:var(--text-color)}.holdings-table td.positive{color:var(--positive-color)}.holdings-table td.negative{color:var(--negative-color)}.metrics-grid{display:flex;flex-direction:column;gap:18px}.performers-list{display:flex;flex-direction:column;gap:14px}.sector-allocation-container .recharts-responsive-container{width:100%!important;min-width:0!important}.grid-item:hover{box-shadow:0 12px 40px #6366f12e;border-color:#a5b4fc}@media (max-width: 600px){.dashboard-grid{grid-template-columns:1fr;gap:16px}.grid-item{padding:1.2rem .7rem}}:root{--background-color: #11131a;--card-background-color: rgba(30, 34, 54, .92);--card-blur: blur(18px) saturate(180%);--text-color: #f4f6f9;--subtitle-color: #a5b4fc;--border-color: rgba(99, 102, 241, .18);--positive-color: #32cd32;--negative-color: #ff6347;--accent-gradient: linear-gradient(90deg, #6366f1 0%, #a5b4fc 100%);--button-background-color: #6366f1;--button-hover-color: #a5b4fc;--demo-button-background-color: #22c55e;--demo-button-hover-color: #16a34a}[data-theme=dark]{--background-color: #181a20;--card-background-color: rgba(30, 34, 54, .85);--text-color: #f4f6f9;--subtitle-color: #a5b4fc;--border-color: rgba(99, 102, 241, .18);--button-background-color: #6366f1;--button-hover-color: #a5b4fc;--demo-button-background-color: #32cd32;--demo-button-hover-color: #22c55e}.portfolio-upload-container{display:flex;justify-content:center;align-items:center;min-height:100vh;background:var(--background-color);color:var(--text-color);padding:20px}.upload-card{background:var(--card-background-color);backdrop-filter:var(--card-blur);-webkit-backdrop-filter:var(--card-blur);border-radius:24px;box-shadow:0 8px 32px #1f26872e;padding:2.5rem 2rem;max-width:800px;width:100%;text-align:center;border:1.5px solid var(--border-color);transition:box-shadow .2s;color:var(--text-color)}.upload-card h1{font-size:2rem;font-weight:700;color:var(--text-color);margin-bottom:10px;letter-spacing:.01em}.upload-card .subtitle{font-size:1.1rem;color:var(--subtitle-color);margin-bottom:30px;font-weight:500}.upload-options{display:flex;justify-content:space-between;gap:24px;margin-bottom:30px;flex-wrap:wrap}.upload-option{flex:1 1 320px;background:#282c40d9;color:var(--text-color);border:1.5px solid var(--border-color);border-radius:18px;padding:1.5rem 1.2rem;text-align:left;box-shadow:0 2px 8px #6366f10f;margin-bottom:12px;transition:box-shadow .2s,border .2s}.upload-option:hover{box-shadow:0 8px 32px #6366f11f;border-color:#a5b4fc}.upload-option h2{font-size:1.25rem;font-weight:600;color:var(--subtitle-color);margin-bottom:10px}.upload-option p{font-size:.98rem;color:var(--text-color);margin-bottom:15px;opacity:.85}.file-upload{display:flex;flex-direction:column;align-items:flex-start}.file-upload-label{display:inline-block;background:var(--accent-gradient);color:#fff;padding:10px 22px;border-radius:999px;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:10px;border:none;transition:background .2s;box-shadow:0 2px 8px #6366f114}.file-upload-label:hover,.file-upload-label.disabled{background:var(--button-hover-color);opacity:.7}.file-upload input{display:none}.file-format-note{font-size:.88rem;color:var(--subtitle-color);margin-top:2px}.template-download .template-download-btn{background:none;color:var(--subtitle-color);border:none;font-size:1rem;font-weight:600;cursor:pointer;padding:0;margin-top:8px;text-decoration:underline;transition:color .2s}.template-download .template-download-btn:hover{color:var(--button-hover-color)}.demo-button{background:var(--demo-button-background-color);color:#fff;padding:10px 22px;border:none;border-radius:999px;cursor:pointer;font-size:1rem;font-weight:600;margin-bottom:8px;transition:background .2s;box-shadow:0 2px 8px #22c55e1a}.demo-button:hover{background:var(--demo-button-hover-color)}.demo-note{font-size:.88rem;color:var(--subtitle-color);margin-top:10px;opacity:.85}.features-preview{margin-top:30px}.features-preview h3{font-size:1.25rem;font-weight:600;color:var(--subtitle-color);margin-bottom:20px}.features-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:20px}.feature-item{display:flex;flex-direction:column;align-items:center;text-align:center}.feature-icon{font-size:2rem;color:var(--button-background-color);margin-bottom:10px}.feature-text{font-size:.98rem;color:var(--text-color);opacity:.92}.loader-overlay{position:fixed;z-index:9999;top:0;right:0;bottom:0;left:0;background:#141622e0;display:flex;flex-direction:column;align-items:center;justify-content:center}.ai-bot-loader{display:flex;flex-direction:column;align-items:center}.bot-face{width:64px;height:64px;background:linear-gradient(135deg,#232946,#6366f1);border-radius:50%;position:relative;margin-bottom:18px;box-shadow:0 4px 24px #5050ff26;animation:bot-bounce 1.2s infinite alternate}@keyframes bot-bounce{0%{transform:translateY(0)}to{transform:translateY(-10px)}}.bot-eye{width:10px;height:10px;background:#f4f6f9;border-radius:50%;position:absolute;top:22px;animation:blink 2.2s infinite}.bot-eye.left{left:16px}.bot-eye.right{right:16px;animation-delay:.2s}@keyframes blink{0%,90%,to{height:10px}92%,98%{height:2px}}.bot-mouth{position:absolute;bottom:16px;left:50%;width:18px;height:8px;border-radius:0 0 18px 18px;background:none;border-bottom:3px solid #a5b4fc;transform:translate(-50%);animation:mouth-smile 1.8s infinite}@keyframes mouth-smile{0%,to{width:18px}50%{width:24px}}.loader-text{color:var(--subtitle-color);font-size:1.2rem;font-weight:600;text-align:center;margin-bottom:.5rem}.loader-subtext{color:#b3b8c5;font-size:1rem;margin-top:.2rem;text-align:center}.file-upload-label.disabled{opacity:.6;pointer-events:none}@media (max-width: 900px){.upload-options{flex-direction:column;gap:16px}}@media (max-width: 600px){.upload-card{padding:1.2rem .7rem}.upload-option{padding:1rem .7rem}}.detailed-analysis-container{background:var(--background-color);color:var(--text-color);max-width:900px;margin:2rem auto;padding:2.5rem 2rem;border-radius:24px;box-shadow:0 8px 32px #1f26872e;border:1.5px solid var(--border-color);font-family:Inter,Segoe UI,Arial,sans-serif}.detailed-analysis-container h1{color:var(--subtitle-color);font-size:2rem;font-weight:700;margin-bottom:2rem}.analysis-section{margin-bottom:2.2rem}.analysis-section h2{color:var(--subtitle-color);font-size:1.25rem;font-weight:600;margin-bottom:1rem;border-bottom:1px solid var(--border-color);padding-bottom:.3rem}.holdings-table-container{overflow-x:auto}.holdings-table{width:100%;border-collapse:collapse;margin-bottom:1rem}.holdings-table th,.holdings-table td{border:1px solid var(--border-color);padding:10px 14px;text-align:left;background:transparent;color:var(--text-color)}.holdings-table th{background:#3c3c5a80;color:var(--subtitle-color);font-weight:600}.sector-pie-container{display:flex;align-items:center;gap:2rem;flex-wrap:wrap}.sector-summary{font-size:1rem;color:var(--text-color);opacity:.85;max-width:300px}.performance-summary{display:flex;gap:2.5rem;font-size:1.1rem;margin-top:.5rem}.perf-label{color:var(--subtitle-color);font-weight:500;margin-right:.5rem}.perf-value{font-weight:700}.risk-tolerance{margin-top:.5rem}.risk-type{color:var(--subtitle-color);font-weight:600;margin-bottom:.5rem}.risk-subtitle{color:var(--subtitle-color);margin-top:.7rem;font-weight:500}.preferences-list>div,.goals-list>div{margin-bottom:.5rem}ul{margin:.5rem 0 .5rem 1.2rem;padding:0}@media (max-width: 700px){.detailed-analysis-container{padding:1.2rem .5rem}.sector-pie-container{flex-direction:column;gap:1rem}.performance-summary{flex-direction:column;gap:.7rem}}.back-arrow-btn{background:none;border:none;cursor:pointer;color:var(--text-color);font-size:1.2rem}.search-result-container{max-width:800px;margin:2rem auto;background:var(--card-background-color);color:var(--text-color);border-radius:24px;box-shadow:0 8px 32px #1f26872e;border:1.5px solid var(--border-color);padding:2.5rem 2rem;font-family:Inter,Segoe UI,Arial,sans-serif}.back-button{background:none;color:var(--subtitle-color);border:none;font-size:1rem;font-weight:600;cursor:pointer;margin-bottom:1.5rem;transition:color .2s}.back-button:hover{color:#fff}.search-result-content{font-size:1.08rem}.search-result-content h1,.search-result-content h2,.search-result-content h3{color:var(--subtitle-color);margin-top:1.5rem}.search-result-content ul{margin-left:1.5rem}.search-result-content table{width:100%;border-collapse:collapse;margin:1rem 0}.search-result-content th,.search-result-content td{border:1px solid var(--border-color);padding:8px 12px}.login-container{display:flex;justify-content:center;align-items:center;min-height:100vh;padding:20px;background-color:var(--background-color, #f4f6f8)}.login-card{background-color:var(--card-background-color, #ffffff);padding:30px 40px;border-radius:12px;box-shadow:0 6px 20px #00000014;width:100%;max-width:480px;text-align:center;color:var(--text-color, #333)}.login-card h2{margin-bottom:15px;color:var(--text-color, #1a2b4d);font-size:26px;font-weight:600}.login-card p{margin-bottom:30px;color:var(--subtitle-color, #555);font-size:16px;line-height:1.6}.form-group{margin-bottom:25px;text-align:left}.form-group label{display:block;margin-bottom:8px;font-weight:500;color:var(--text-color, #444);font-size:14px}.form-group input{width:100%;padding:14px 16px;border:1px solid var(--border-color, #d1d5db);border-radius:8px;box-sizing:border-box;font-size:16px;transition:border-color .2s ease-in-out,box-shadow .2s ease-in-out}.form-group input:focus{border-color:var(--primary-color, #6366f1);outline:none;box-shadow:0 0 0 3px var(--primary-color-light-transparent, rgba(99, 102, 241, .2))}.login-button{width:100%;padding:14px 15px;background-color:var(--primary-color, #6366f1);color:#fff;border:none;border-radius:8px;font-size:16px;font-weight:600;cursor:pointer;transition:background-color .2s ease-in-out}.login-button:hover:not(:disabled){background-color:var(--primary-color-dark, #4f46e5)}.login-button:disabled{background-color:var(--disabled-color, #9ca3af);cursor:not-allowed}.error-message,.success-message{padding:12px 15px;border-radius:6px;margin-bottom:20px;font-size:14px;text-align:left}.error-message{color:var(--error-text-color, #991b1b);background-color:var(--background-color, #fef2f2);border:1px solid var(--error-border-color, #fecaca)}.success-message{color:var(--success-text-color, #14532d);background-color:var(--background-color, #f0fdf4);border:1px solid var(--success-border-color, #bbf7d0)}.loader-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background-color:#ffffffd9;display:flex;justify-content:center;align-items:center;z-index:1000}.ai-bot-loader{display:flex;flex-direction:column;align-items:center;padding:30px;background-color:var(--card-background-color, #fff);border-radius:12px;box-shadow:0 5px 20px #0000001a}.bot-face{width:60px;height:60px;background-color:var(--primary-color, #6366f1);border-radius:50%;position:relative;margin-bottom:20px;animation:bounce 1.2s infinite alternate ease-in-out}.bot-eye{width:10px;height:10px;background-color:#fff;border-radius:50%;position:absolute;top:20px}.bot-eye.left{left:15px}.bot-eye.right{right:15px}.bot-mouth{width:25px;height:8px;background-color:#fff;border-radius:0 0 10px 10px;position:absolute;bottom:15px;left:50%;transform:translate(-50%)}.loader-text{font-size:18px;font-weight:500;color:var(--text-color, #333)}@keyframes bounce{0%{transform:translateY(0)}to{transform:translateY(-12px)}}.custom-google-btn{display:flex;align-items:center;justify-content:center;gap:8px;background:var(--background-color);color:var(--text-color);border:1px solid #ddd;border-radius:4px;font-size:1rem;padding:.5rem 1rem;width:100%;max-width:320px;margin:0 auto;box-shadow:0 1px 2px #0000000a;transition:background .2s,box-shadow .2s;cursor:pointer}.custom-google-btn:hover:not(:disabled){background:var(--primary-color-dark);box-shadow:0 2px 8px #4285f414}.custom-google-icon{width:22px;height:22px;margin-right:8px;flex-shrink:0;display:inline-block;vertical-align:middle}
