:root{--bg-primary:#f5f5f5;--bg-secondary:#fff;--bg-tertiary:#f8f9fa;--text-primary:#333;--text-secondary:#374151;--text-muted:#9ca3af;--border-color:#e1e8ed;--input-bg:#fff;--input-border:#e1e8ed;--input-focus:#27ae60;--shadow:#0000001a;--gradient-primary:linear-gradient(135deg,#2c3e50,#3498db);--gradient-secondary:linear-gradient(135deg,#27ae60,#2ecc71);--card-background:#fff;--primary-blue:#3498db;--primary-blue-hover:#2980b9;--warning-background:#ffc1071a;--warning-color:#ffc107;--success-color:#10b981;--success-hover:#059669;--error-color:#ef4444;--bg-hover:#e8e8e8}[data-theme=dark]{--bg-primary:#0f172a;--bg-secondary:#1e293b;--bg-tertiary:#334155;--text-primary:#f1f5f9;--text-secondary:#cbd5e1;--text-muted:#64748b;--border-color:#334155;--input-bg:#334155;--input-border:#475569;--input-focus:#10b981;--shadow:#0000004d;--gradient-primary:linear-gradient(135deg,#1e293b,#3b82f6);--gradient-secondary:linear-gradient(135deg,#059669,#10b981);--card-background:#1e293b;--primary-blue:#60a5fa;--primary-blue-hover:#3b82f6;--warning-background:#fbbf2426;--warning-color:#fbbf24;--success-color:#10b981;--success-hover:#059669;--error-color:#ef4444;--bg-hover:#475569}*{box-sizing:border-box}*,html{margin:0;padding:0}html{height:auto;scrollbar-gutter:stable}body{background-color:#f5f5f5;background-color:var(--bg-primary);color:#333;color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;line-height:1.6;margin:0;min-height:100%;transition:background-color .3s ease,color .3s ease}.App,body{padding-bottom:0}.App{margin-left:60px;margin-right:0;min-height:100vh;position:relative;transition:margin-right .3s cubic-bezier(.4,0,.2,1);z-index:1}.App.ai-sidebar-open{margin-right:550px}.App.side-panel-open{margin-right:400px}.App.fullscreen-mode{min-height:100vh}.App-header{background:linear-gradient(135deg,#2c3e50,#3498db);background:var(--gradient-primary);box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--shadow);color:#fff;padding:2rem;position:relative;text-align:center;z-index:10}.App-header h1{font-size:2.5rem;margin-bottom:.5rem}.App-header p{font-size:1.2rem;opacity:.9}main{margin:0 auto;max-width:1200px;padding:1rem 2rem 2rem}main.fullscreen-layout{height:100vh;margin:0 auto;max-width:1200px;overflow:hidden;padding:1rem 2rem 2rem}.yield-analyzer{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 6px #0000001a;box-shadow:0 4px 6px var(--shadow);overflow:hidden}.analyzer-container{padding:2rem}.input-section{margin-bottom:2rem}.input-section h2{border-bottom:2px solid #27ae60;border-bottom:2px solid var(--input-focus);color:#333;color:var(--text-primary);margin-bottom:1rem;padding-bottom:.5rem}.input-form{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:6px;padding:1.5rem;transition:background-color .3s ease,border-color .3s ease}.portfolio-inputs h3{color:#374151;color:var(--text-secondary);margin-bottom:1rem}.portfolio-row{align-items:center;display:flex;gap:1rem;margin-bottom:.8rem}.percentage-input,.ticker-input{background-color:#fff;background-color:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:4px;color:#333;color:var(--text-primary);font-size:1rem;padding:.5rem;transition:border-color .3s ease,background-color .3s ease}.percentage-input:focus,.ticker-input:focus{border-color:#27ae60;border-color:var(--input-focus);outline:none}.ticker-input{text-transform:uppercase;width:120px}.percentage-input{width:100px}.percentage-input::-webkit-inner-spin-button,.percentage-input::-webkit-outer-spin-button{-webkit-appearance:none;margin:0}.percentage-input[type=number]{-webkit-appearance:textfield;appearance:textfield}.add-btn,.remove-btn{border:none;border-radius:4px;cursor:pointer;font-size:.9rem;padding:.4rem .8rem;transition:background-color .2s,transform .2s}.add-btn{background-color:#27ae60;background-color:var(--input-focus);color:#fff;margin-top:.5rem}.add-btn:hover{background-color:#1e8449;box-shadow:0 2px 8px #27ae604d;transform:translateY(-1px)}.remove-btn{background-color:#dc3545}.remove-btn:hover{background-color:#c82333;transform:translateY(-1px)}.form-group{margin:1rem 0}.form-group label{color:#374151;color:var(--text-secondary);font-weight:500}.form-group input{background-color:#fff;background-color:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:4px;color:#333;color:var(--text-primary);font-size:1rem;padding:.5rem;transition:border-color .3s ease,background-color .3s ease;width:200px}.form-group input:focus{border-color:#27ae60;border-color:var(--input-focus);outline:none}.analyze-btn{background:linear-gradient(135deg,#3498db,#2980b9);border-radius:4px;margin-top:1rem;padding:.8rem 2rem;transition:transform .2s,box-shadow .2s}.analyze-btn:hover:not(:disabled){box-shadow:0 4px 8px #3498db4d}.auth-overlay{align-items:center;animation:fadeIn .3s ease;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;position:fixed;right:0;top:0;z-index:2000}.auth-container{animation:slideUp .3s ease;background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 20px 40px #0000004d;margin:20px;max-width:450px;position:relative;width:100%}.auth-header{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);padding:2rem 2rem 1rem;position:relative;text-align:center}.auth-header h2{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.auth-header p{font-size:.95rem;margin-bottom:0}.auth-close,.auth-header p{color:#374151;color:var(--text-secondary)}.auth-close{align-items:center;background:none;border:none;border-radius:6px;cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:1rem;top:1rem;transition:all .2s ease}.auth-close:hover{background:#f8f9fa;background:var(--bg-tertiary);color:#333;color:var(--text-primary)}.social-login-section{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);padding:1.5rem 2rem}.social-login-buttons{display:flex;flex-direction:column;gap:.75rem;margin-bottom:1.5rem}.social-btn{align-items:center;background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);cursor:pointer;display:flex;font-size:.95rem;font-weight:500;gap:.75rem;justify-content:center;padding:.875rem 1rem;position:relative;transition:all .2s ease;width:100%}.social-btn:hover{box-shadow:0 4px 12px #0000001a;transform:translateY(-1px)}.google-btn{border-color:#4285f4;color:#333;color:var(--text-primary)}.google-btn:hover{background:#4285f40d;border-color:#4285f4;box-shadow:0 4px 12px #4285f426}.apple-btn{border-color:#000;color:#333;color:var(--text-primary)}.apple-btn:hover{background:#0000000d;border-color:#000;box-shadow:0 4px 12px #00000026}[data-theme=dark] .apple-btn{border-color:#fff}[data-theme=dark] .apple-btn:hover{background:#ffffff0d;border-color:#fff;box-shadow:0 4px 12px #ffffff26}.facebook-btn{border-color:#1877f2;color:#333;color:var(--text-primary)}.facebook-btn:hover{background:#1877f20d;border-color:#1877f2;box-shadow:0 4px 12px #1877f226}.social-btn svg{flex-shrink:0}.divider{margin:0;position:relative;text-align:center}.divider:before{background:#e1e8ed;background:var(--border-color);content:"";height:1px;left:0;position:absolute;right:0;top:50%}.divider span{background:#fff;background:var(--bg-secondary);color:#9ca3af;color:var(--text-muted);font-size:.875rem;padding:0 1rem;position:relative;z-index:1}@media (max-width:768px){.social-login-section{padding:1rem 1.5rem}.social-btn{font-size:.9rem;padding:.75rem 1rem}}.auth-form{padding:2rem}.auth-form .form-group{margin-bottom:1.5rem}.auth-form .form-group label{color:#333;color:var(--text-primary);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.auth-form .form-group input{background:#fff;background:var(--input-bg);border:2px solid #e1e8ed;border:2px solid var(--input-border);border-radius:8px;box-sizing:border-box;color:#333;color:var(--text-primary);font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.auth-form .form-group input:focus{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 0 0 3px #10b9811a;outline:none}.auth-form .form-group input.error{border-color:#ef4444;box-shadow:0 0 0 3px #ef44441a}.auth-form .form-group input::placeholder{color:#9ca3af;color:var(--text-muted)}.error-message{display:block;font-size:.875rem;margin-bottom:0;margin-top:.5rem}.submit-error{background:#ef44441a;border:1px solid #ef444433;border-radius:6px;margin-bottom:1rem;padding:.75rem;text-align:center}.auth-submit-btn{align-items:center;background:#27ae60;background:var(--input-focus);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1rem;font-weight:600;gap:.5rem;justify-content:center;margin-bottom:1.5rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.auth-submit-btn:hover:not(:disabled){background:#1e8449;box-shadow:0 4px 12px #27ae604d;transform:translateY(-1px)}.auth-submit-btn:disabled{cursor:not-allowed;opacity:.7;transform:none}.loading-spinner{align-items:center;display:flex;gap:.5rem}.loading-spinner svg{animation:spin 1s linear infinite}.auth-switch{margin-bottom:1rem;text-align:center}.auth-switch p{color:#374151;color:var(--text-secondary);font-size:.9rem;margin:0}.switch-btn{background:none;border:none;color:#27ae60;color:var(--input-focus);cursor:pointer;font-size:.9rem;font-weight:600;margin-left:.5rem;text-decoration:underline;transition:color .2s ease}.switch-btn:hover{color:#1e8449}.auth-forgot{margin-bottom:1rem;text-align:center}.forgot-btn{background:none;border:none;color:#374151;color:var(--text-secondary);cursor:pointer;font-size:.875rem;text-decoration:underline;transition:color .2s ease}.forgot-btn:hover{color:#333;color:var(--text-primary)}.auth-footer{border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);padding:1.5rem 2rem 2rem;text-align:center}.auth-footer p{color:#374151;color:var(--text-secondary);font-size:.9rem;margin:0 0 .5rem}.auth-footer small{color:#9ca3af;color:var(--text-muted);font-size:.8rem;font-style:italic}@media (max-width:768px){.auth-container{margin:10px;max-width:none}.auth-header{padding:1.5rem 1.5rem 1rem}.auth-form{padding:1.5rem}.auth-footer{padding:1rem 1.5rem 1.5rem}.auth-header h2{font-size:1.5rem}}.donation-overlay{animation:fadeIn .3s ease;overflow-y:auto;padding:20px}.donation-page{margin:0 auto;max-width:1200px}.donation-impact-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(4,1fr);margin-bottom:4rem}.impact-card{background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:12px;box-shadow:0 4px 12px #00000014;padding:1.25rem;text-align:center}.impact-icon{font-size:3rem;margin-bottom:1rem}.impact-card h3{color:#333;color:var(--text-primary);font-size:1.25rem;font-weight:600;margin-bottom:.75rem}.impact-card p{color:#374151;color:var(--text-secondary);font-size:.95rem;line-height:1.6}.kofi-cta-section{background:linear-gradient(135deg,#fff,#f5f5f5);background:linear-gradient(135deg,var(--bg-secondary) 0,var(--bg-primary) 100%);border-radius:16px;box-shadow:0 4px 20px #0000001a;margin-bottom:4rem;padding:3rem 2rem;text-align:center}.kofi-content{margin:0 auto;max-width:700px}.thank-you-icon{display:flex;justify-content:center;margin-bottom:1.5rem}.kofi-cta-section h2{color:#333;color:var(--text-primary);font-size:2rem;font-weight:600;margin-bottom:1rem}.kofi-description{color:#374151;color:var(--text-secondary);font-size:1.1rem;line-height:1.7;margin-bottom:2rem}.kofi-button-large{align-items:center;background:#ff5e5b;border-radius:12px;box-shadow:0 4px 16px #ff5e5b4d;color:#fff;display:inline-flex;font-size:1.25rem;font-weight:600;gap:1rem;padding:1.25rem 3rem;text-decoration:none;transition:all .3s ease}.kofi-button-large:hover{background:#ff4643;box-shadow:0 8px 24px #ff5e5b66;transform:translateY(-3px) scale(1.02)}.kofi-button-large svg{height:28px;width:28px}.community-section{background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:16px;padding:2rem;text-align:center}.community-description{color:#374151;color:var(--text-secondary);font-size:1.1rem;line-height:1.7;margin-bottom:2rem;margin-left:auto;margin-right:auto;max-width:800px}.community-actions{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin-top:2rem}.community-action{align-items:center;background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:10px;color:#333;color:var(--text-primary);display:flex;font-size:1rem;gap:.75rem;padding:1rem 1.5rem}.action-icon{font-size:1.5rem}.donate-button-large{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:12px;box-shadow:0 4px 16px #10b9814d;color:#fff;cursor:pointer;display:inline-flex;font-size:1.25rem;font-weight:600;gap:1rem;padding:1.25rem 3rem;text-decoration:none;transition:all .3s ease}.donate-button-large:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 8px 24px #10b98166;transform:translateY(-3px) scale(1.02)}.donate-button-large svg{height:28px;width:28px}.donation-overlay{align-items:center;background:#000000b3;bottom:0;display:flex;justify-content:center;left:0;padding:2rem;position:fixed;right:0;top:0;z-index:2000}.donation-modal{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:16px;box-shadow:0 20px 60px #0006;max-height:90vh;max-width:500px;overflow-y:auto;position:relative;width:100%}.modal-close{align-items:center;background:none;border:none;border-radius:6px;color:#374151;color:var(--text-secondary);cursor:pointer;display:flex;justify-content:center;padding:.5rem;position:absolute;right:1rem;top:1rem;transition:all .2s ease;z-index:10}.modal-close:hover{background:#f8f9fa;background:var(--bg-tertiary);color:#333;color:var(--text-primary)}.modal-header{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);padding:2rem 2rem 1.5rem;text-align:center}.modal-header h2{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:.5rem}.modal-header p{color:#374151;color:var(--text-secondary);font-size:.95rem}.donation-form{padding:2rem}.amount-section{margin-bottom:2rem}.amount-section label{color:#333;color:var(--text-primary);display:block;font-size:.95rem;font-weight:600;margin-bottom:1rem}.amount-buttons{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(5,1fr);margin-bottom:1.5rem}.amount-btn{background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem .5rem;text-align:center;transition:all .2s ease}.amount-btn:hover{border-color:#10b981;transform:translateY(-1px)}.amount-btn.selected{background:#10b981;border-color:#10b981;color:#fff}.custom-amount{margin-top:1rem}.custom-amount label{color:#333;color:var(--text-primary);display:block;font-size:.9rem;font-weight:500;margin-bottom:.5rem}.custom-input-wrapper{align-items:center;display:flex;position:relative}.currency-symbol{color:#374151;color:var(--text-secondary);left:1rem}.custom-input-wrapper input{background:#f5f5f5;background:var(--bg-primary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);font-size:1rem;padding:.875rem 1rem .875rem 2rem;transition:all .2s ease;width:100%}.custom-input-wrapper input:focus{border-color:#10b981;box-shadow:0 0 0 3px #10b9811a;outline:none}.payment-section{margin-bottom:2rem}.payment-section label{color:#333;color:var(--text-primary);display:block;font-size:.95rem;font-weight:600;margin-bottom:1rem}.stripe-element{background:#f8f9fa;background:var(--bg-tertiary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;padding:1rem}.mock-stripe-form .form-group{margin-bottom:1rem}.mock-stripe-form .form-group:last-child{margin-bottom:0}.form-row{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:1fr 1fr}.stripe-input{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;box-sizing:border-box;color:#333;color:var(--text-primary);font-size:.9rem;padding:.75rem;width:100%}.stripe-input:focus{border-color:#10b981;outline:none}.stripe-note{align-items:center;color:#374151;color:var(--text-secondary);display:flex;font-size:.875rem;gap:.5rem;margin-top:1rem}.stripe-note svg{color:#10b981}.donation-summary{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;margin-bottom:2rem;padding:1.5rem}.summary-row{align-items:center;color:#374151;color:var(--text-secondary);display:flex;font-size:.95rem;justify-content:space-between}.summary-row.total{color:#333;color:var(--text-primary);font-size:1.25rem;font-weight:600}.donate-btn{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 1.5rem;transition:all .2s ease;width:100%}.donate-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b9814d;transform:translateY(-1px)}.donate-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.processing{align-items:center;display:flex;gap:.5rem}.processing svg{animation:spin 1s linear infinite}.donation-success{padding:3rem 2rem;text-align:center}.success-icon{display:flex;justify-content:center;margin-bottom:1.5rem}.donation-success h2{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:1rem}.donation-success p{color:#374151;color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1rem}.success-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:1rem 2rem;transition:all .2s ease}.success-btn:hover{background:linear-gradient(135deg,#059669,#047857)}@media (max-width:768px){.donation-impact-grid{grid-template-columns:1fr}.donate-button-large{font-size:1.1rem;padding:1rem 2rem}.community-actions{align-items:stretch;flex-direction:column}.amount-buttons{grid-template-columns:repeat(3,1fr)}.donation-modal{margin:1rem;max-width:100%}}.legal-page{margin:0 auto;max-width:900px;padding:2rem}.legal-header{border-bottom:2px solid #e1e8ed;border-bottom:2px solid var(--border-color);margin-bottom:3rem;padding:2rem 0 3rem;text-align:center}.legal-header h1{color:#333;color:var(--text-primary);font-size:2.5rem;font-weight:700;margin-bottom:1rem}.last-updated{color:#374151;color:var(--text-secondary);font-size:.95rem;font-style:italic}.legal-content{line-height:1.8}.legal-section{margin-bottom:3rem}.legal-section h2{border-bottom:2px solid var(--accent-primary);font-size:1.75rem;margin-bottom:1rem;padding-bottom:.5rem}.legal-section h2,.legal-section h3{color:#333;color:var(--text-primary);font-weight:600}.legal-section h3{font-size:1.25rem;margin:1.5rem 0 .75rem}.legal-section p{margin-bottom:1rem}.legal-section p,.legal-section ul{color:#374151;color:var(--text-secondary)}.legal-section ul{margin:1rem 0 1rem 2rem}.legal-section li{margin-bottom:.5rem}.warning-box{background:linear-gradient(135deg,#ef44441a,#dc26261a);border-left:4px solid #ef4444;border-radius:8px;margin:1.5rem 0;padding:1.5rem}.warning-box strong{color:#ef4444;display:block;font-size:1.1rem;margin-bottom:.5rem}.warning-box p{color:#333;color:var(--text-primary);margin-bottom:1rem}.warning-box p:last-child{margin-bottom:0}.contact-page{background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:16px;box-shadow:0 4px 12px #00000014;margin:0 auto;max-width:700px;padding:2rem}.contact-header{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);margin-bottom:1.5rem;padding:0 0 1.5rem;text-align:center}.contact-header h1{color:#333;color:var(--text-primary);font-size:2rem;font-weight:700;margin-bottom:.5rem}.contact-header p{color:#374151;color:var(--text-secondary);font-size:1.1rem}.contact-reasons{display:inline-block;list-style:none;margin:.75rem 0;padding:0;text-align:left}.contact-reasons li{color:#374151;color:var(--text-secondary);font-size:1rem;line-height:1.6;padding:.25rem 0}.contact-reasons li:before{color:#3498db;color:var(--primary-blue,#3b82f6);content:"✦ ";font-size:.85rem;margin-right:.5rem}.contact-email-line{align-items:center;background:#3b82f614;border:1px solid #3b82f640;border-radius:10px;display:inline-flex;flex-direction:column;gap:.4rem;margin-top:1.25rem;padding:.85rem 1.5rem;text-align:center}.contact-email-label{color:#374151;color:var(--text-secondary);font-size:.85rem}.contact-email-line a{color:#3498db;color:var(--primary-blue,#3b82f6);font-size:1rem;font-weight:600;text-decoration:none}.contact-email-line a:hover{text-decoration:underline}.contact-form-container{padding:0}.contact-form-container h2{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:1.5rem}.contact-form .form-group{margin-bottom:1.5rem}.contact-form label{color:#333;color:var(--text-primary);display:block;font-size:.95rem;font-weight:600;margin-bottom:.5rem}.contact-form input,.contact-form select,.contact-form textarea{background:#f5f5f5;background:var(--bg-primary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);font-family:inherit;font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.contact-form input:focus,.contact-form select:focus,.contact-form textarea:focus{border-color:#3498db;border-color:var(--primary-blue,#3b82f6);box-shadow:0 0 0 3px #3b82f626;outline:none}.contact-form textarea{min-height:120px;resize:vertical}.submit-btn{align-items:center;background:#3498db;background:var(--primary-blue,#3b82f6);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 1.5rem;transition:all .3s ease;width:100%}.submit-btn:hover:not(:disabled){background:#2980b9;background:var(--primary-blue-hover,#2563eb);box-shadow:0 4px 12px #10b9814d;transform:translateY(-2px)}.submit-btn:disabled{cursor:not-allowed;opacity:.6}.submitting{align-items:center;display:flex;gap:.5rem}.submitting svg{animation:spin 1s linear infinite}.success-message{padding:3rem 2rem;text-align:center}.success-message .success-icon{display:flex;justify-content:center;margin-bottom:1.5rem}.success-message h3{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:600;margin-bottom:1rem}.success-message p{color:#374151;color:var(--text-secondary);font-size:1rem;line-height:1.6}.footer-link:hover{color:var(--accent-primary)}@media (max-width:768px){.contact-page,.legal-page{padding:1rem}.contact-header h1,.legal-header h1{font-size:1.75rem}.legal-section h2{font-size:1.5rem}}.success-btn:hover{background:#1e8449;box-shadow:0 2px 8px #27ae604d;transform:translateY(-1px)}@media (max-width:768px){.donation-overlay{padding:10px}.donation-container{margin:0;max-height:95vh;max-width:none}.donation-header{padding:1.5rem 1.5rem 1rem}.donation-content{padding:1.5rem}.donation-footer{padding:1rem 1.5rem 1.5rem}.donation-header h2{font-size:1.5rem}.amount-buttons{grid-template-columns:repeat(3,1fr)}.form-row{grid-template-columns:1fr}}.results-section h2{border-bottom:2px solid #27ae60;padding-bottom:.5rem}.summary-cards{grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.card{border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;box-shadow:0 2px 4px #0000000d;transition:background-color .3s ease,border-color .3s ease;transition:transform .2s,box-shadow .2s}.card:hover{box-shadow:0 4px 8px #0000001a;transform:translateY(-2px)}.card h3{color:#374151;color:var(--text-secondary)}.metric{color:#333;color:var(--text-primary);font-size:2rem;font-weight:700;margin:0}.chart-section{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;padding:1.5rem;transition:background-color .3s ease,border-color .3s ease}.dividend-chart h3{color:#2c3e50;margin-bottom:1rem;text-align:center}.error-message{background-color:#f8d7da;border:1px solid #f5c6cb;border-radius:4px;color:#721c24}.dividend-chart svg{display:block;margin:0 auto}@media (max-width:768px){.App-header h1{font-size:2rem}.App-header p{font-size:1rem}.analyzer-container,main{padding:1rem}.portfolio-row{align-items:stretch;flex-direction:column}.percentage-input,.ticker-input{margin-bottom:.5rem;width:100%}.summary-cards{grid-template-columns:1fr}.form-group input{width:100%}}.app-nav{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.nav-tab{background:#ffffff1a;border:2px solid #ffffff4d;border-radius:25px;color:#fff;cursor:pointer;font-size:1rem;font-weight:500;padding:.75rem 1.5rem;transition:all .3s ease}.nav-tab:hover{background:#fff3;border-color:#ffffff80}.nav-tab.active{background:#fff;background:var(--bg-secondary);border-color:#e1e8ed;border-color:var(--border-color);color:#333;color:var(--text-primary)}.app-footer{background:#f8f9fa;background:var(--bg-tertiary);border-top:1px solid var(--border);clear:both;color:#374151;color:var(--text-secondary);margin-bottom:0;margin-top:2rem;padding:1.5rem 1rem;position:relative;text-align:center;z-index:1}.footer-content{margin:0 auto;max-width:1200px}.footer-description{font-size:.9rem;line-height:1.5;margin-bottom:1rem}.footer-divider{background:var(--border);height:1px;margin:1rem auto;max-width:80%;opacity:.5}.footer-company{margin-bottom:.75rem}.company-name{color:#333;color:var(--text-primary);font-weight:600;letter-spacing:.5px;margin-bottom:.5rem}.copyright{font-size:.85rem;margin:.5rem 0}.copyright,.data-attribution{color:#374151;color:var(--text-secondary)}.data-attribution{font-size:.8rem;margin:.4rem 0 0}.data-attribution a{color:#10b981;color:var(--accent-primary,#10b981);text-decoration:none}.data-attribution a:hover{text-decoration:underline}.footer-links{align-items:center;display:flex;flex-wrap:wrap;font-size:.85rem;gap:.5rem;justify-content:center;margin-top:1rem}.footer-link{color:#374151;color:var(--text-secondary);cursor:pointer;transition:color .2s ease}.footer-link:hover{color:#333;color:var(--text-primary);text-decoration:underline}.footer-separator{color:#374151;color:var(--text-secondary);opacity:.5}@media (max-width:768px){.app-footer{padding:1.5rem 1rem}.footer-description{font-size:.9rem}.company-name{font-size:1rem}.footer-links{font-size:.8rem}}.etf-analyzer{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 6px #0000001a;box-shadow:0 4px 6px var(--shadow);overflow:visible}.analyzer-header{background:linear-gradient(135deg,#27ae60,#2ecc71);background:var(--gradient-secondary)}.how-it-works-banner{background:#3b82f60f;border-bottom:1px solid #3b82f633;text-align:left}.how-it-works-toggle{align-items:center;background:none;border:none;color:#3498db;color:var(--primary-blue,#3b82f6);cursor:pointer;display:flex;font-family:inherit;font-size:.875rem;font-weight:600;gap:.5rem;padding:.65rem 1rem;width:100%}.how-it-works-toggle:hover{background:#3b82f614}.how-it-works-body{border-top:1px solid #3b82f626;padding:.75rem 1.25rem 1rem}.how-it-works-body ol{color:#374151;color:var(--text-secondary);font-size:.875rem;line-height:1.7;margin:0;padding-left:1.25rem}.how-it-works-body li{margin-bottom:.3rem}.how-it-works-body li strong{color:#333;color:var(--text-primary)}.analyzer-header h1{font-size:2.2rem;margin-bottom:.5rem}.analyzer-header .subtitle{font-size:1.1rem;opacity:.9}.etf-input-form{background:#fff;background:var(--bg-secondary);padding:2rem}.form-group{margin-bottom:2rem}.form-group label{color:#2c3e50;display:block;font-weight:600;margin-bottom:.5rem}.input-wrapper{display:inline-block;position:relative;width:100%}.currency-symbol{color:#666;font-weight:600;left:15px;position:absolute;top:50%;transform:translateY(-50%);z-index:1}.input-wrapper input{padding-left:40px!important}.form-group input,.form-group select{background:#fff;background:var(--input-bg);border:2px solid #e1e8ed;border:2px solid var(--input-border);border-radius:6px;color:#333;color:var(--text-primary);font-size:1rem;padding:12px 15px;transition:border-color .3s ease;width:100%}.form-group input:focus,.form-group select:focus{border-color:#27ae60;border-color:var(--input-focus);outline:none}.form-hint{color:#666;display:block;font-size:.9rem;margin-top:.5rem}.allocations-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1rem}.total-allocation{border-radius:20px;font-size:.9rem;font-weight:600;padding:.5rem 1rem}.total-allocation.valid{background:#d4edda;border:1px solid #c3e6cb;color:#155724}.total-allocation.invalid{background:#f8d7da;border:1px solid #f5c6cb;color:#721c24}.allocations-list{margin-bottom:1rem}.allocation-row{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;display:flex;gap:1rem;margin-bottom:1rem;padding:1rem}.allocation-inputs{display:flex;flex:1 1;gap:1rem}.allocation-inputs input{margin:0}.percentage-input{position:relative;width:120px}.percentage-symbol{color:#666;right:15px;top:50%;transform:translateY(-50%)}.percentage-input input{padding-right:35px}.remove-btn{align-items:center;background:#e74c3c;color:#fff;display:flex;font-size:1rem;height:30px;justify-content:center;transition:background-color .3s ease;width:30px}.remove-btn:hover{background:#c0392b}.add-allocation-btn{background:#27ae60;border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:1rem;padding:.75rem 1.5rem;transition:background-color .3s ease}.add-allocation-btn:hover:not(:disabled){background:#219a52}.add-allocation-btn:disabled{background:#bdc3c7;cursor:not-allowed}.spinner{animation:spin 1s linear infinite;border:2px solid #ffffff4d;border-top-color:#fff;height:20px;width:20px}.examples-section{border-top:1px solid #e1e8ed;margin-top:2rem;padding-top:1.5rem}.examples-section h4{color:#2c3e50;margin-bottom:1rem}.example-buttons{display:flex;flex-wrap:wrap;gap:1rem}.example-btn{background:#3498db;border:none;border-radius:20px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:background-color .3s ease}.example-btn:hover{background:#2980b9}.results-section{padding:2rem}.results-section h2{color:#2c3e50;font-size:1.8rem;margin-bottom:1.5rem}.summary-cards{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin-bottom:2rem}.card{background:#fff;background:var(--bg-secondary);border-left:4px solid #27ae60;border-left:4px solid var(--input-focus);border-radius:8px;box-shadow:0 2px 4px #0000001a;padding:1.5rem;text-align:center}.card.primary{border-left-color:#27ae60}.card h3{color:#666;font-size:.9rem;letter-spacing:.5px;margin-bottom:.5rem;text-transform:uppercase}.card .metric{color:#2c3e50;font-size:1.8rem;font-weight:700;margin:0}.insights-section{margin-bottom:2rem}.insights-section h3{color:#2c3e50;margin-bottom:1rem}.insights-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.insight-card{border-left:4px solid #3498db;border-radius:6px;padding:1rem}.insight-card.positive{background:#d4edda;border-left-color:#27ae60}.insight-card.neutral{background:#fff;background:var(--bg-secondary);border-left-color:#374151;border-left-color:var(--text-secondary)}.insight-card h4{color:#2c3e50;margin-bottom:.5rem}.etf-charts{margin:2rem 0}.charts-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:1fr 1fr;grid-template-rows:1fr 1fr;min-height:1200px}@media (max-width:1024px){.charts-grid{grid-template-columns:1fr;grid-template-rows:auto auto auto auto;min-height:auto}}.chart-container{box-shadow:0 2px 4px #0000001a;box-shadow:0 2px 4px var(--shadow)}.chart-container.full-width{grid-column:1/-1}.chart-container h3{color:#333;color:var(--text-primary);margin-bottom:.5rem}.chart{min-height:400px;overflow-x:auto;width:100%}.summary-table{background:#fff;background:var(--bg-secondary);border-collapse:collapse;border-radius:4px;box-shadow:0 1px 3px #0000001a;margin:1rem 0;overflow:hidden;width:100%}.summary-table th{background:#f8f9fa;background:var(--bg-tertiary);border-bottom:2px solid #dee2e6;color:#333;color:var(--text-primary);font-weight:600;padding:12px 16px;text-align:left}.summary-table td{border-bottom:1px solid #dee2e6;color:#495057;padding:12px 16px}.summary-table tbody tr:hover{background:#f8f9fa}.summary-table tbody tr:last-child td{border-bottom:none}.summary-table .text-right{text-align:right}.d3-tooltip{background:#000c;border-radius:4px;color:#fff;font:12px sans-serif;padding:8px;pointer-events:none;position:absolute;text-align:center}.etf-breakdown{margin-top:2rem}.etf-breakdown h3{color:#2c3e50;margin-bottom:1rem}.etf-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr))}.etf-card{background:#fff;border:1px solid #e1e8ed;border-radius:8px;overflow:hidden}.etf-header{align-items:center;background:#f8f9fa;border-bottom:1px solid #e1e8ed;display:flex;justify-content:space-between;padding:1rem}.etf-header h4{color:#2c3e50;font-size:1.2rem;margin:0}.allocation{background:#27ae60;border-radius:15px;color:#fff;font-size:.9rem;font-weight:600;padding:.25rem .75rem}.etf-metrics{padding:1rem}.metric-row{border-bottom:1px solid #f8f9fa;display:flex;justify-content:space-between;margin-bottom:.5rem;padding-bottom:.5rem}.metric-row:last-child{border-bottom:none;margin-bottom:0}.metric-row span:first-child{color:#666;font-size:.9rem}.metric-row span:last-child{color:#2c3e50;font-weight:600}.error-message,.loading-section{padding:2rem;text-align:center}.error-card,.loading-card{background:#fff;border-radius:8px;box-shadow:0 2px 4px #0000001a;margin:0 auto;max-width:400px;padding:2rem}.loading-card h3{color:#3498db;margin-bottom:1rem}.error-card{border-left:4px solid #e74c3c}.error-card h3{color:#e74c3c;margin-bottom:1rem}.loading-spinner{animation:spin 1s linear infinite;border:4px solid #f3f3f3;border-radius:50%;border-top-color:#3498db;height:40px;margin:1rem auto;width:40px}.unified-analyzer-container{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 6px #0000001a;box-shadow:0 4px 6px var(--shadow);margin-bottom:2rem;overflow:hidden}.tab-content-area-full{width:100%}.tab-content-area,.tab-content-area-full{background:#fff;background:var(--bg-secondary);overflow-y:auto}.tab-content-area{flex:1 1}.unified-analyzer{background:#fff;background:var(--bg-secondary);overflow:visible}.tab-button,.tab-button-vertical,.tab-navigation,.tab-navigation-sidebar{display:none}.coming-soon-content{margin:2rem auto;max-width:600px;padding:3rem;text-align:center}.coming-soon-icon{font-size:4rem;margin-bottom:1rem}.coming-soon-content h3{color:#333;color:var(--text-primary);font-size:1.5rem;margin-bottom:1.5rem}.feature-list{list-style:none;padding:0;text-align:left}.feature-list li{background:#f5f5f5;background:var(--bg-primary);border-left:3px solid var(--primary-color);border-radius:6px;color:#374151;color:var(--text-secondary);margin:.5rem 0;padding:.75rem 1rem}.tab-content{animation:tabFadeIn .3s ease-in}@keyframes tabFadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.analyzer-header{background:linear-gradient(135deg,#2c3e50,#3498db);background:var(--gradient-primary);color:#fff;padding:2rem;position:relative;text-align:center}.analyzer-header h2{font-size:1.8rem;font-weight:600;margin:0 0 .5rem}.analyzer-header p{font-size:1.1rem;margin:0;opacity:.9}.header-donate-btn{align-items:center;background:#fff3;border:1px solid #ffffff4d;border-radius:20px;color:#fff;cursor:pointer;display:inline-flex;font-size:.85rem;font-weight:500;gap:.4rem;padding:.5rem 1rem;position:absolute;right:2rem;text-decoration:none;top:1.5rem;transition:all .2s ease}.header-donate-btn:hover{background:#ff6b6b33;border-color:#ff6b6b80;box-shadow:0 2px 8px #ff6b6b4d;transform:translateY(-1px)}.portfolio-input-section{padding:0 2rem .75rem}.settings-bubbles-container{grid-gap:1rem;align-items:start;display:grid;gap:1rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem}.settings-bubble{background:#f8f9fa;background:var(--bg-tertiary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:12px;min-width:0;overflow:visible;padding:1.25rem}.settings-bubble.settings-bubble--wide{grid-column:1/-1}.settings-bubble.settings-bubble--half-left{grid-column:1/-1;justify-self:start;width:50%}@media (max-width:900px){.settings-bubble.settings-bubble--half-left{width:100%}}.settings-bubble .bubble-label{color:#333;color:var(--text-primary);display:block;font-size:12px;font-weight:600;margin-bottom:.75rem}.settings-bubble small{color:#374151;color:var(--text-secondary);display:block;font-size:11px;line-height:1.3;margin-top:.5rem}.date-input,.settings-input,.settings-select{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:8px;color:#333;color:var(--text-primary);font-size:15px;font-weight:500;padding:.75rem;transition:all .2s ease;width:100%}.date-input:focus,.settings-input:focus,.settings-select:focus{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 0 0 3px #10b9811a;outline:none}.settings-select{cursor:pointer}.portfolio-settings{grid-gap:2rem;border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));margin-bottom:2rem;padding-bottom:2rem}.portfolio-settings .form-group{margin-bottom:0}.portfolio-settings .form-group label{color:#333;color:var(--text-primary);display:block;font-size:1rem;font-weight:600;margin-bottom:.5rem}.portfolio-settings .form-group input,.portfolio-settings .form-group select{background:#fff;background:var(--input-bg);border:2px solid #e1e8ed;border:2px solid var(--input-border);border-radius:8px;box-sizing:border-box;color:#333;color:var(--text-primary);font-size:1rem;padding:.875rem 1rem;transition:all .2s ease;width:100%}.portfolio-settings .form-group input:focus,.portfolio-settings .form-group select:focus{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 0 0 3px #10b9811a;outline:none}.portfolio-settings .form-group small{color:#9ca3af;color:var(--text-muted);display:block;font-size:.875rem;line-height:1.4;margin-top:.5rem}.holdings-section{margin-bottom:2rem;padding:0 2rem}.holdings-section .holding-row{grid-gap:.2rem;align-items:center;background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;display:grid;gap:.2rem;grid-template-columns:120px 78px 1fr 36px;margin-bottom:.15rem;padding:.15rem .3rem}.holdings-section .percentage-input,.holdings-section .symbol-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:4px;box-sizing:border-box;color:#333;color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.8rem;font-weight:400;height:28px;line-height:1;padding:.35rem .5rem;width:100%}.holdings-section .symbol-input{text-transform:uppercase}.holdings-section .remove-holding-btn{grid-column:auto}.portfolio-strategies{grid-gap:.6rem;background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;display:grid;gap:.6rem;grid-template-columns:repeat(5,1fr);margin-bottom:2rem;padding:1rem}.portfolio-strategies h4{color:#333;color:var(--text-primary);font-size:1rem;font-weight:600;grid-column:1/-1;margin:0 0 1rem;padding-top:1rem}.strategy-card{background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;cursor:pointer;display:flex;flex-direction:column;gap:.25rem;padding:.6rem .75rem;text-align:center;transition:all .25s ease}.strategy-card:hover{background:#f5f5f5;background:var(--bg-primary);border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 4px 12px #10b98133;transform:translateY(-2px)}.strategy-icon{font-size:1.25rem;line-height:1}.strategy-name{color:#333;color:var(--text-primary);font-size:.8rem;font-weight:600;margin:0}.strategy-description{color:#374151;color:var(--text-secondary);font-size:.7rem;line-height:1.3;margin:0}@media (max-width:1400px){.portfolio-strategies{grid-template-columns:repeat(4,1fr)}}@media (max-width:1024px){.portfolio-strategies{grid-template-columns:repeat(3,1fr)}}@media (max-width:768px){.portfolio-strategies{gap:.75rem;grid-template-columns:repeat(2,1fr);padding:1rem}.strategy-card{padding:.75rem}}.holdings-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.holdings-header h3{color:#333;color:var(--text-primary);font-size:1.3rem;font-weight:600;margin:0}.add-holding-btn{background:#27ae60;background:var(--input-focus);border:none;color:#fff}.add-holding-btn:hover{background:#1e8449;box-shadow:0 2px 8px #27ae604d}.portfolio-save-trigger{background:#3498db!important;background:var(--primary-blue,#3b82f6)!important;color:#fff!important}.portfolio-save-trigger:hover{background:#2563eb!important;box-shadow:0 2px 8px #3b82f64d!important}.portfolio-load-trigger{background:#8b5cf6!important;color:#fff!important}.portfolio-load-trigger:hover{background:#7c3aed!important;box-shadow:0 2px 8px #8b5cf64d!important}.portfolio-save-overlay{align-items:center;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);background:#00000080;display:flex;inset:0;justify-content:center;position:fixed;z-index:10000}.portfolio-save-modal{background:#f5f5f5;background:var(--bg-primary,#fff);border-radius:12px;box-shadow:0 8px 32px #00000040;display:flex;flex-direction:column;max-height:80vh;max-width:520px;overflow:hidden;width:90%}.portfolio-save-header{align-items:center;border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color,#e5e7eb);display:flex;justify-content:space-between;padding:16px 20px}.portfolio-save-header h3{font-size:1.1rem;margin:0}.portfolio-save-close{background:none;border:none;border-radius:4px;color:#374151;color:var(--text-secondary);cursor:pointer;font-size:1.5rem;line-height:1;padding:4px 8px}.portfolio-save-close:hover{background:#f8f9fa;background:var(--bg-tertiary)}.portfolio-save-form{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color,#e5e7eb);padding:16px 20px}.portfolio-save-form label{color:#374151;color:var(--text-secondary);display:block;font-size:.85rem;font-weight:600;margin-bottom:6px}.portfolio-save-input-row{display:flex;gap:8px}.portfolio-save-input{background:#fff;background:var(--bg-secondary,#f9fafb);border:1px solid #e1e8ed;border:1px solid var(--border-color,#d1d5db);border-radius:6px;color:#333;color:var(--text-primary);flex:1 1;font-size:.95rem;outline:none;padding:10px 12px;transition:border-color .2s}.portfolio-save-input:focus{border-color:#3498db;border-color:var(--primary-blue,#3b82f6);box-shadow:0 0 0 2px #3b82f626}.portfolio-save-btn{background:#3498db;background:var(--primary-blue,#3b82f6);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:10px 20px;transition:background .2s;white-space:nowrap}.portfolio-save-btn:hover:not(:disabled){background:#2563eb}.portfolio-save-btn:disabled{cursor:not-allowed;opacity:.5}.portfolio-save-error{color:#e74c3c;font-size:.85rem;margin-top:8px}.portfolio-save-success{color:#10b981;font-size:.85rem;font-weight:500;margin-top:8px}.portfolio-save-preview{background:#f8f9fa;background:var(--bg-tertiary,#f3f4f6);border-radius:6px;color:#374151;color:var(--text-secondary);font-size:.82rem;line-height:1.4;margin-top:10px;padding:8px 10px}.portfolio-save-preview .preview-label{font-weight:600;margin-right:4px}.portfolio-save-preview .preview-value{color:#9ca3af;color:var(--text-muted)}.portfolio-save-list{flex:1 1;overflow-y:auto;padding:0 20px 12px}.portfolio-save-list-header{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color,#e5e7eb);color:#374151;color:var(--text-secondary);font-size:.82rem;font-weight:600;margin-bottom:4px;padding:12px 0 6px}.portfolio-save-empty{color:#374151;color:var(--text-secondary);padding:32px 16px;text-align:center}.portfolio-save-item{align-items:center;border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color,#f0f0f0);display:flex;gap:12px;justify-content:space-between;padding:10px 0}.portfolio-save-item--clickable{border-radius:6px;cursor:pointer;margin:0 -8px;padding:10px 8px;transition:background .15s}.portfolio-save-item--clickable:hover{background:#f8f9fa;background:var(--bg-tertiary,#f3f4f6)}.portfolio-save-item-info{flex:1 1;min-width:0}.portfolio-save-item-name{color:#333;color:var(--text-primary);font-size:.95rem;font-weight:600}.portfolio-save-item-detail,.portfolio-save-item-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.portfolio-save-item-detail{color:#374151;color:var(--text-secondary);font-size:.82rem;margin-top:2px}.portfolio-save-item-meta{color:#9ca3af;color:var(--text-muted,#9ca3af);font-size:.78rem;margin-top:2px}.portfolio-save-item-actions{display:flex;flex-shrink:0;gap:6px}.portfolio-save-item-delete,.portfolio-save-item-load,.portfolio-save-item-use{background:#f8f9fa;background:var(--bg-tertiary,#f3f4f6);border:none;border-radius:4px;cursor:pointer;font-size:.8rem;padding:4px 8px;transition:background .15s}.portfolio-save-item-load{background:#3498db;background:var(--primary-blue,#3b82f6);color:#fff;font-weight:500;padding:4px 12px}.portfolio-save-item-load:hover{background:#2563eb}.portfolio-save-item-delete:hover{background:#fee2e2}.portfolio-save-item-delete.confirm{background:#e74c3c;color:#fff;font-weight:600}.portfolio-save-footer{border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color,#e5e7eb);color:#9ca3af;color:var(--text-muted);font-size:.8rem;padding:10px 20px;text-align:center}.empty-portfolio{background:#f8f9fa;background:var(--bg-tertiary);border:2px dashed #e1e8ed;border:2px dashed var(--border-color);border-radius:8px;color:#374151;color:var(--text-secondary);padding:3rem 2rem;text-align:center}.empty-portfolio p{font-size:1.1rem;margin:0}.holdings-list{margin:0;padding:0}.holding-row{grid-gap:.5rem;align-items:center;background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;display:grid;gap:.5rem;grid-template-columns:62px 78px 1fr 36px;margin-bottom:.5rem;padding:.5rem .75rem;transition:all .2s ease}.holding-row:hover{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 2px 8px #10b9811a}.holding-symbol{min-width:0}.holding-symbol .symbol-input{width:100%}.holding-name-sector{align-items:center;display:flex;gap:8px;min-width:0;overflow:hidden;white-space:nowrap}.holding-name-sector span{overflow:hidden;text-overflow:ellipsis}.type-select{border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:6px;cursor:pointer;font-size:.9rem;padding:.5rem}.symbol-input,.type-select{background:#fff;background:var(--input-bg);color:#333;color:var(--text-primary)}.symbol-input{border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:4px;box-sizing:border-box;font-size:.8rem;height:auto;line-height:normal;padding:.15rem .3rem;text-transform:uppercase;width:100%}.holding-percentage{color:#333;color:var(--text-primary);font-size:1rem;position:relative}.percentage-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:4px;box-sizing:border-box;color:#333;color:var(--text-primary);font-size:.8rem;height:auto;line-height:normal;padding:.15rem .3rem;width:100%}.percentage-symbol{color:#374151;color:var(--text-secondary);font-size:.875rem;font-weight:600;position:absolute;right:.625rem}.remove-holding-btn{align-items:center;background:#ef4444;border:none;border-radius:50%;color:#fff;display:flex;flex-shrink:0;font-size:1rem;font-weight:700;height:28px;justify-content:center;transition:all .2s ease;width:28px}.remove-holding-btn:hover{background:#dc2626;transform:scale(1.1)}.portfolio-summary{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;margin-bottom:2rem;margin-top:1rem;padding:1rem}.allocation-breakdown{align-items:center;color:#374151;color:var(--text-secondary);display:flex;font-size:.9rem;font-weight:500;justify-content:space-between}.quick-start-section{margin-top:2rem}.quick-start-section h4{color:#333;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1.5rem}.analyze-portfolio-btn{align-items:center;background:linear-gradient(135deg,#2c3e50,#3498db);background:var(--gradient-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;margin:0 auto 2rem;max-width:400px;padding:1rem 2rem;transition:all .2s ease;width:33%}.analyze-portfolio-btn:hover:not(:disabled){box-shadow:0 6px 20px #3498db4d;transform:translateY(-2px)}.analyze-portfolio-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.analyzing{align-items:center;display:flex;gap:.5rem}.analyzing svg{animation:spin 1s linear infinite}.holdings-breakdown h4{color:#333;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1rem}.holdings-table{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.holding-summary{align-items:center;border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:grid;grid-template-columns:40px 1fr 80px 80px;padding:.75rem 1rem}.holding-summary:last-child{border-bottom:none}.holding-type-indicator{align-items:center;display:flex;justify-content:center}.holding-type-indicator .type-badge{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:4px;color:#374151;color:var(--text-secondary);display:inline-flex;font-size:.8rem;font-weight:600;height:28px;justify-content:center;width:28px}.holding-symbol{font-size:1rem}.holding-type-text{color:#374151;color:var(--text-secondary);font-size:.8rem;font-weight:500;text-transform:uppercase}.holding-allocation{color:#333;color:var(--text-primary);font-weight:600;text-align:right}@media (max-width:768px){.settings-bubbles-container{gap:1rem;grid-template-columns:1fr}.portfolio-settings{gap:1.5rem;grid-template-columns:1fr}.holdings-header{align-items:stretch;flex-direction:column;gap:1rem}.holding-row{gap:.75rem;grid-template-columns:1fr}.holding-percentage{grid-template-columns:1fr auto}.results-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.holding-summary{grid-template-columns:30px 1fr 60px 60px;padding:.5rem}.analyzer-header{padding:1.5rem}.analyzer-header h2{font-size:1.5rem}.portfolio-input-section{padding:1.5rem}.quick-start-section{padding:1rem}.bubble-category{margin-bottom:1rem}.bubbles-row{justify-content:flex-start}.quick-add-bubble{font-size:.8rem;padding:.4rem .8rem}}.left-sidebar{background:#fff;background:var(--bg-secondary);border-right:1px solid #e1e8ed;border-right:1px solid var(--border-color);bottom:0;box-shadow:2px 0 8px #0000001a;box-shadow:2px 0 8px var(--shadow);left:0;pointer-events:auto;position:fixed;top:0;transition:width .3s ease;width:48px;z-index:9999}.left-sidebar.expanded{overflow:visible;width:180px}.sidebar-nav{display:flex;flex-direction:column;flex-shrink:0;height:100%;padding:.5rem 0}.sidebar-nav-spacer{flex:1 1}.nav-item{align-items:center;background:#0000;border:none;border-radius:0 8px 8px 0;color:#333;color:var(--text-primary);cursor:pointer;display:flex;gap:0;margin-left:0;overflow:hidden;padding:.35rem 0;text-align:left;transition:all .2s ease;white-space:nowrap;width:100%}.nav-item:hover{background:#f8f9fa;background:var(--bg-tertiary)}.nav-item:hover .nav-icon{color:#27ae60;color:var(--input-focus)}.nav-item:before{background:#27ae60;background:var(--input-focus);border-radius:0 3px 3px 0;content:"";height:0;left:0;position:absolute;top:50%;transform:translateY(-50%);transition:height .2s ease;width:3px}.nav-item:hover:before{height:70%}.nav-item.active{background:#f8f9fa;background:var(--bg-tertiary);color:#27ae60;color:var(--input-focus)}.nav-item.active:before{background:#27ae60;background:var(--input-focus);height:100%}.nav-item.active .nav-icon{color:#27ae60;color:var(--input-focus)}.nav-icon{align-items:center;display:flex;flex-shrink:0;height:32px;justify-content:center;margin:0;min-width:48px;padding:0;transition:all .2s ease;width:48px}.nav-icon svg{display:block;height:18px;width:18px}.nav-icon{position:relative}.nav-label{font-size:.85rem;font-weight:500;margin-left:.25rem;opacity:0;pointer-events:none;transform:translateX(-10px);transition:opacity .15s ease 0s,visibility 0s ease 0s,transform .15s ease 0s;visibility:hidden;white-space:nowrap}.left-sidebar.expanded .nav-label{opacity:1;pointer-events:auto;transform:translateX(0);transition:opacity .2s ease .25s,visibility 0s ease .25s,transform .2s ease .25s;visibility:visible}.nav-label-content{align-items:center;display:inline-flex;gap:.35rem;position:relative}.nav-icon.nav-inline{color:inherit;height:18px;margin:0;min-width:18px;padding:0;pointer-events:auto;width:18px}.nav-item{position:relative}.nav-icon[data-tooltip]:after{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow);color:#333;color:var(--text-primary);content:attr(data-tooltip);font-size:.85rem;font-weight:500;left:calc(100% + 4px);margin-top:2px;opacity:0;padding:.5rem .75rem;pointer-events:none;position:absolute;top:50%;transform:translateY(-50%);transition:opacity .2s ease,visibility .2s ease;visibility:hidden;white-space:nowrap;z-index:1001}.left-sidebar:not(.expanded) .nav-icon[data-tooltip]:hover:after{opacity:1;visibility:visible}.left-sidebar.expanded .nav-icon[data-tooltip]:after{display:none}.left-sidebar.expanded .nav-icon.nav-inline[data-tooltip]:after{display:block!important;left:calc(100% + 6px);opacity:0;right:auto;visibility:hidden;z-index:10000}.left-sidebar.expanded .nav-icon.nav-inline[data-tooltip]:hover:after{opacity:1!important;visibility:visible!important}.left-sidebar.expanded .nav-item,.left-sidebar.expanded .nav-label,.left-sidebar.expanded .nav-label-content,.left-sidebar:not(.expanded) .nav-item{overflow:visible}.toggle-item{margin-bottom:.15rem}.toggle-item .nav-icon{color:#374151;color:var(--text-secondary);position:relative}.toggle-item:hover .nav-icon{color:#333;color:var(--text-primary)}.logo-toggle .logo-icon{position:relative}.logo-toggle .logo-image{border-radius:4px;height:28px;transition:opacity .2s ease;width:28px}.logo-toggle .expand-overlay{left:50%;opacity:0;pointer-events:none;position:absolute;top:50%;transform:translate(-50%,-50%);transition:opacity .2s ease}.logo-toggle:hover .logo-image{opacity:0}.left-sidebar.expanded .logo-toggle:hover .logo-image,.logo-toggle:hover .expand-overlay{opacity:1}.left-sidebar.expanded .logo-toggle:hover .expand-overlay{opacity:0}.nav-divider{background:#e1e8ed;background:var(--border-color);height:1px;margin:.15rem .75rem}.nav-spacer{flex:1 1}.donation-nav,.donation-nav .nav-icon{color:#ff6b6b}.donation-nav:hover{background:#ff6b6b1a}.donation-nav:hover .nav-icon{color:#ff5252}.profile-nav{margin-top:.5rem}.profile-nav .nav-icon{color:#27ae60;color:var(--input-focus)}.profile-nav:hover{background:#10b9811a}.sidebar-backdrop{animation:fadeIn .2s ease;background:#0000004d}.settings-backdrop,.sidebar-backdrop{bottom:0;left:0;position:fixed;right:0;top:0;z-index:999}.settings-backdrop{background:#0000}.profile-bubble{animation:slideUp .2s ease;background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;bottom:2rem;box-shadow:0 8px 24px #0000004d;left:70px;min-width:240px;overflow:hidden;padding:0;position:fixed;z-index:1001}.left-sidebar.expanded~.profile-bubble{left:170px}.profile-header{align-items:center;background:#f8f9fa;background:var(--bg-tertiary);border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:flex;gap:.75rem;padding:1rem}.profile-avatar{align-items:center;background:#27ae60;background:var(--input-focus);border-radius:50%;color:#fff;display:flex;flex-shrink:0;height:40px;justify-content:center;width:40px}.profile-info{flex:1 1;min-width:0}.profile-name{color:#333;color:var(--text-primary);font-size:.95rem;font-weight:600;margin-bottom:.15rem}.profile-email,.profile-name{overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.profile-email{color:#374151;color:var(--text-secondary);font-size:.8rem}@keyframes slideUp{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.menu-item{align-items:center;background:none;border:none;border-radius:0;color:#333;color:var(--text-primary);cursor:pointer;display:flex;gap:12px;padding:12px 16px;text-align:left;transition:all .2s ease;width:100%}.menu-item:hover{background:#f8f9fa;background:var(--bg-tertiary)}.menu-item.auth-item{font-weight:500}.menu-item.auth-item:hover{background:#f8f9fa;background:var(--bg-tertiary)}.menu-item.auth-item .menu-item-icon,.menu-item.auth-item:hover{color:#27ae60;color:var(--input-focus)}.menu-item-icon{align-items:center;display:flex;height:20px;justify-content:center;width:20px}.menu-item-content{flex:1 1}.menu-item-label{display:block;font-size:.9rem;font-weight:500}.menu-item-description{color:#374151;color:var(--text-secondary);display:block;font-size:.75rem;margin-top:2px}.menu-divider{background:#e1e8ed;background:var(--border-color);height:1px;margin:.5rem 0}@media (max-width:768px){.App{margin-bottom:70px;margin-left:0}.left-sidebar{border-right:none;border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);bottom:0;height:60px;left:0;right:0;top:auto;width:100%}.left-sidebar.expanded{height:80vh;width:100%}.sidebar-nav{flex-direction:row;justify-content:space-around;overflow-x:auto;padding:.5rem}.left-sidebar.expanded .sidebar-nav{flex-direction:column;overflow-y:auto;padding:1rem}.nav-item{padding:.5rem}.nav-icon{height:44px;min-width:44px;width:44px}.nav-divider{display:none}.left-sidebar.expanded .nav-divider{display:block}.nav-spacer{display:none}.left-sidebar.expanded .nav-spacer{display:block}.profile-bubble{bottom:70px;left:50%;right:auto;transform:translateX(-50%)}.left-sidebar.expanded~.profile-bubble{bottom:80vh;left:50%}}.ai-commentary-container{animation:slideInUp .4s ease;background:#fff;background:var(--bg-secondary);border:2px solid #27ae60;border:2px solid var(--input-focus);border-radius:12px;box-shadow:0 4px 12px #10b98126;margin:2rem auto;max-width:100%;overflow:hidden;padding:0}@keyframes slideInUp{0%{opacity:0;transform:translateY(20px)}to{opacity:1;transform:translateY(0)}}.ai-commentary-header{background:linear-gradient(135deg,#10b9811a,#10b9810d);border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);gap:1rem;padding:1.5rem}.ai-commentary-header,.ai-icon{align-items:center;display:flex}.ai-icon{background:#27ae60;background:var(--input-focus);border-radius:12px;color:#fff;flex-shrink:0;height:48px;justify-content:center;width:48px}.ai-title-section{display:flex;flex:1 1;flex-direction:column;gap:.25rem}.ai-commentary-title{color:#333;color:var(--text-primary);font-size:1.25rem;font-weight:700;margin:0}.ai-badge{align-items:center;background:#10b9811a;border-radius:4px;color:#27ae60;color:var(--input-focus);display:inline-flex;font-size:.75rem;font-weight:600;padding:.25rem .5rem;width:-webkit-fit-content;width:fit-content}.ai-commentary-content{color:#333;color:var(--text-primary);line-height:1.7;padding:1.5rem}.ai-paragraph{color:#333;color:var(--text-primary);font-size:1rem;margin:0 0 1rem}.ai-paragraph:last-child{margin-bottom:0}.ai-commentary-footer{align-items:center;background:#f8f9fa;background:var(--bg-tertiary);border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);color:#374151;color:var(--text-secondary);display:flex;font-size:.875rem;gap:.5rem;padding:1rem 1.5rem}.ai-commentary-footer svg{color:#374151;color:var(--text-secondary);flex-shrink:0;height:16px;width:16px}.ai-commentary-loading{color:#374151;color:var(--text-secondary);padding:2rem;text-align:center}.ai-loading-spinner{animation:spin .8s linear infinite;border:3px solid #e1e8ed;border-top-color:#27ae60;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--input-focus);display:inline-block;height:24px;width:24px}@media (max-width:768px){.ai-commentary-container{margin:1.5rem 0}.ai-commentary-header{padding:1rem}.ai-icon{height:40px;width:40px}.ai-commentary-title{font-size:1.1rem}.ai-commentary-content{padding:1rem}.ai-paragraph{font-size:.95rem}.ai-commentary-footer{font-size:.8rem;padding:.75rem 1rem}}.home-page{display:flex;flex-direction:column;margin:0 auto;max-width:1200px;min-height:calc(100vh - 60px)}.hero-section{background:linear-gradient(135deg,#2d5a7b,#3d7ea6);border-radius:16px;box-shadow:0 4px 20px #00000026;margin-bottom:2.5rem;padding:1.5rem 2rem;text-align:center}.hero-title{font-size:2.25rem;margin-bottom:.5rem}.hero-subtitle{font-size:1.15rem;margin-bottom:.75rem}.hero-description{font-size:.95rem;line-height:1.5;margin:0 auto 1rem}.hero-free-message{background:#ffffff1a;border:1px solid #fff3;border-radius:12px;margin:0 auto .75rem;max-width:800px;padding:1rem}.hero-free-message p{color:#fff;font-size:.9rem;line-height:1.4;margin:0}.hero-free-message p:first-child{margin-bottom:.4rem}.hero-free-message p:last-of-type{margin-bottom:.75rem}.hero-free-message strong{color:#fff;font-size:1rem}.hero-free-message .donate-button-small{display:flex;margin:0 auto;width:-webkit-fit-content;width:fit-content}.donate-button-small{align-items:center;background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 2px 8px #10b9814d;color:#fff;cursor:pointer;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.75rem 1.5rem;text-decoration:none;transition:all .3s ease}.donate-button-small:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166;transform:translateY(-2px)}.donate-button-small svg{flex-shrink:0}.home-cards-grid{grid-gap:1.5rem;display:grid;flex:1 1;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));margin-bottom:3rem}.home-card{background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:12px;cursor:pointer;display:flex;flex-direction:column;gap:.75rem;overflow:hidden;padding:1.5rem;position:relative;transition:all .3s ease}.home-card:before{background:linear-gradient(90deg,#2d5a7b,#3d7ea6);content:"";height:3px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.home-card:hover:before{opacity:1}.home-card:hover{border-color:#3d7ea6;box-shadow:0 8px 20px #2d5a7b4d;transform:translateY(-4px)}.home-card-icon{font-size:2.5rem;line-height:1}.home-card-title{color:#333;color:var(--text-primary);font-size:1.25rem;font-weight:600;margin:0}.home-card-description{color:#374151;color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0}.home-card-arrow{align-self:flex-end;color:#667eea;color:var(--card-color,#667eea);font-size:1.5rem;opacity:0;transform:translateX(-10px);transition:all .3s ease}.home-card:hover .home-card-arrow{opacity:1;transform:translateX(0)}.home-card-features{display:flex;flex-wrap:wrap;gap:.4rem;list-style:none;margin:0;padding:0}.home-card-features li{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#374151;color:var(--text-secondary);font-size:.75rem;padding:.2rem .55rem;white-space:nowrap}.home-card:hover .home-card-features li{border-color:#3d7ea6;color:#333;color:var(--text-primary)}.hero-highlights{display:flex;flex-wrap:wrap;gap:2rem;justify-content:center;margin:1.25rem 0}.hero-highlight-item{align-items:center;background:#ffffff1a;border:1px solid #ffffff26;border-radius:10px;display:flex;flex-direction:column;gap:.2rem;padding:.5rem 1rem}.hero-highlight-number{color:#fff;font-size:1.6rem;font-weight:700;line-height:1}.hero-highlight-label{color:#b8dff8;font-size:.75rem;font-weight:500;letter-spacing:.03em;text-transform:uppercase}.home-data-sources{background:linear-gradient(135deg,#2d5a7b0f,#3d7ea60f);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;margin:1rem 0 0;padding:2rem 2.5rem;text-align:center}.home-data-label{color:#374151;color:var(--text-secondary);font-size:.7rem;font-weight:600;letter-spacing:.15em;margin-bottom:1rem;text-transform:uppercase}.home-data-badges{display:flex;flex-wrap:wrap;gap:.6rem;justify-content:center}.home-data-badge{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:20px;color:#374151;color:var(--text-secondary);font-size:.8rem;font-weight:500;padding:.35rem 1rem;transition:all .25s ease}.home-data-badge:hover{background:#3d7ea614;border-color:#3d7ea6;color:#2d5a7b;transform:translateY(-1px)}.home-footer{color:#374151;color:var(--text-secondary);font-size:.85rem;margin-top:1.5rem;padding:1.5rem 0 .5rem;position:relative;text-align:center}.home-footer:before{background:linear-gradient(90deg,#0000,#e1e8ed,#0000);background:linear-gradient(90deg,#0000,var(--border-color),#0000);content:"";display:block;height:1px;margin:0 auto 1.5rem;max-width:400px;width:60%}.home-footer p{letter-spacing:.02em;line-height:1.6}@media (max-width:768px){.home-page{padding:1rem}.hero-section{padding:1.25rem 1rem}.hero-title{font-size:1.5rem}.hero-subtitle{font-size:1rem}.hero-description{font-size:.9rem}.hero-free-message{font-size:.8rem;padding:.85rem}.hero-free-message strong{font-size:.9rem}.donate-button-small{font-size:.85rem;padding:.6rem 1.1rem}.home-cards-grid{gap:1rem;grid-template-columns:1fr}.home-card{padding:1.25rem}.hero-highlights{gap:1rem}.hero-highlight-item{padding:.35rem .7rem}.hero-highlight-number{font-size:1.25rem}.hero-highlight-label{font-size:.65rem}.home-data-badges{gap:.35rem}.home-data-badge{font-size:.7rem;padding:.2rem .6rem}}.hero-section .kofi-button-large{background:linear-gradient(135deg,#2d5a7b,#3d7ea6);border-radius:16px;box-shadow:0 4px 20px #00000026;margin-bottom:3rem;padding:3rem 2rem;text-align:center}.hero-title{color:#fff;font-size:3rem;font-weight:700;margin-bottom:1rem;text-shadow:0 2px 8px #0003}.hero-subtitle{color:#e0f2ff;font-size:1.5rem;font-weight:500;margin-bottom:1.5rem}.hero-description{color:#f0f9ff;font-size:1.1rem;line-height:1.8;margin:0 auto 2rem;max-width:900px}.hero-section .kofi-button-large{margin-top:1rem}.hero-section .thank-you-icon{margin-bottom:1.5rem}.hero-section .thank-you-icon,.home-quick-action{display:flex;justify-content:center}.discussion-bubble{align-items:center;background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:9999px;color:#333;color:var(--text-primary);cursor:pointer;display:inline-flex;font-weight:600;gap:.5rem;padding:.5rem .875rem;transition:all .2s ease}.discussion-bubble:hover{background:#f8f9fa;background:var(--bg-tertiary);transform:translateY(-1px)}.bubble-icon{font-size:1.1rem}.bubble-label{font-size:.95rem}.features-grid{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(350px,1fr));margin-bottom:4rem}.feature-card{background:#fff;background:var(--bg-secondary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:16px;box-shadow:0 4px 12px #00000014;cursor:pointer;overflow:hidden;padding:2rem;position:relative;transition:all .3s ease}.feature-card:before{background:linear-gradient(90deg,#10b981,#3b82f6 50%,#8b5cf6);content:"";height:4px;left:0;opacity:0;position:absolute;right:0;top:0;transition:opacity .3s ease}.feature-card:hover:before{opacity:1}.feature-card:hover{border-color:#3d7ea6;box-shadow:0 12px 24px #2d5a7b4d;transform:translateY(-8px)}.feature-icon{font-size:4rem}.feature-icon,.feature-title{margin-bottom:1rem;text-align:center}.feature-title{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:600}.feature-description{color:#374151;color:var(--text-secondary);font-size:1rem;line-height:1.6;margin-bottom:1.5rem;text-align:center}.feature-highlights{list-style:none;margin:1.5rem 0;padding:0}.feature-highlights li{align-items:center;color:#333;color:var(--text-primary);display:flex;gap:.5rem;padding:.5rem 0}.highlight-bullet{color:var(--accent-primary);font-size:1.2rem;font-weight:700}.feature-button{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 2px 8px #10b9814d;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;margin-top:1rem;padding:1rem;transition:all .3s ease;width:100%}.feature-button:hover{background:linear-gradient(135deg,#059669,#047857);box-shadow:0 4px 12px #10b98166;transform:scale(1.02)}.getting-started-section{background:#fff;background:var(--bg-secondary);border-radius:16px;margin-bottom:4rem;padding:2rem}.section-title{color:#333;color:var(--text-primary);font-size:2rem;font-weight:600;margin-bottom:2rem;text-align:center}.steps-container{grid-gap:2rem;display:grid;gap:2rem;grid-template-columns:repeat(auto-fit,minmax(280px,1fr))}.step-card{background:#f5f5f5;background:var(--bg-primary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:12px;padding:2rem;text-align:center}.step-number{align-items:center;background:linear-gradient(135deg,#3b82f6,#2563eb);border-radius:50%;box-shadow:0 4px 12px #3b82f64d;color:#fff;display:flex;font-size:1.5rem;font-weight:700;height:50px;justify-content:center;margin:0 auto 1rem;width:50px}.step-card h3{color:#333;color:var(--text-primary);font-size:1.25rem;margin-bottom:.75rem}.step-card p{color:#374151;color:var(--text-secondary);line-height:1.6}.cta-section{background:linear-gradient(135deg,#8b5cf6,#7c3aed);border-radius:16px;box-shadow:0 4px 20px #8b5cf64d;color:#fff;margin-bottom:2rem;padding:3rem 2rem;text-align:center}.cta-section h2{font-size:2rem;margin-bottom:1rem;text-shadow:0 2px 4px #0003}.cta-section p{font-size:1.1rem;opacity:.95}@media (max-width:768px){.hero-title{font-size:2rem}.hero-subtitle{font-size:1.2rem}.hero-description{font-size:1rem}.features-grid,.steps-container{grid-template-columns:1fr}.home-page{padding:1rem}}.reddit-feed{border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);flex-shrink:0;margin-top:0;padding:1rem 1.5rem 0}.reddit-feed-header{margin-bottom:1rem}.reddit-feed-title{align-items:center;color:#333;color:var(--text-primary);font-size:.9rem;font-weight:600}.reddit-feed-title,.reddit-subreddit-tabs{display:flex;gap:.5rem;margin-bottom:.75rem}.reddit-tab{background:#0000;border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#374151;color:var(--text-secondary);cursor:pointer;flex:1 1;font-size:.85rem;font-weight:500;padding:.5rem .75rem;transition:all .2s ease}.reddit-tab:hover{background:#f8f9fa;background:var(--bg-tertiary)}.reddit-tab.active,.reddit-tab:hover{border-color:#27ae60;border-color:var(--input-focus)}.reddit-tab.active{background:#27ae60;background:var(--input-focus);color:#fff}.reddit-feed-content{min-height:200px}.reddit-empty,.reddit-error,.reddit-loading{align-items:center;color:#374151;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:2rem 1rem;text-align:center}.spinner{animation:spin .8s linear infinite;border:3px solid #e1e8ed;border-top-color:#27ae60;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--input-focus);height:30px;margin-bottom:.75rem;width:30px}@keyframes spin{to{transform:rotate(1turn)}}.reddit-empty p,.reddit-error p,.reddit-loading p{font-size:.85rem;margin-top:.5rem}.reddit-error button{background:#27ae60;background:var(--input-focus);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.85rem;margin-top:.75rem;padding:.5rem 1rem;transition:opacity .2s ease}.reddit-error button:hover{opacity:.8}.reddit-posts{display:flex;flex-direction:column;gap:.75rem}.reddit-post{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:inherit;display:block;padding:.75rem;text-decoration:none;transition:all .2s ease}.reddit-post:hover{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--shadow);transform:translateY(-1px)}.reddit-post-header{align-items:center;display:flex;font-size:.75rem;justify-content:space-between;margin-bottom:.5rem}.reddit-post-author{color:#374151;color:var(--text-secondary);font-weight:500}.reddit-post-time{color:#9ca3af;color:var(--text-muted)}.reddit-post-title{-webkit-line-clamp:2;line-clamp:2;-webkit-box-orient:vertical;color:#333;color:var(--text-primary);display:-webkit-box;font-size:.85rem;font-weight:500;line-height:1.4;margin-bottom:.5rem;overflow:hidden;text-overflow:ellipsis}.reddit-post-stats{color:#374151;color:var(--text-secondary);display:flex;font-size:.75rem;gap:1rem}.reddit-stat{align-items:center;display:flex;gap:.25rem}.reddit-stat svg{opacity:.7}.reddit-feed-footer{border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);margin-top:1rem;padding-top:.75rem}.reddit-view-more{color:#27ae60;color:var(--input-focus);display:block;font-size:.85rem;font-weight:500;padding:.5rem;text-align:center;text-decoration:none;transition:opacity .2s ease}.reddit-view-more:hover{opacity:.8}.reddit-feed::-webkit-scrollbar{width:6px}.reddit-feed::-webkit-scrollbar-track{background:#0000}.reddit-feed::-webkit-scrollbar-thumb{background:#e1e8ed;background:var(--border-color);border-radius:3px}.reddit-feed::-webkit-scrollbar-thumb:hover{background:#9ca3af;background:var(--text-muted)}@media (max-width:768px){.reddit-feed{max-height:300px}.reddit-subreddit-tabs{flex-direction:column}.reddit-tab{width:100%}}.stock-analysis{margin:0 auto;max-width:1400px;padding:2rem;width:100%}.stock-search-container{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--shadow);margin-bottom:2rem;padding:2rem}.search-header h2{color:#333;color:var(--text-primary);font-size:1.75rem;font-weight:600;margin:0 0 .5rem}.search-subtitle{color:#374151;color:var(--text-secondary);font-size:.95rem;margin:0 0 1.5rem}.search-bar{align-items:center;display:flex;gap:1rem}.ticker-input{background:#f5f5f5;background:var(--bg-primary);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);flex:1 1;font-size:1rem;font-weight:500;padding:.875rem 1.25rem;transition:all .2s ease}.ticker-input:focus{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 0 0 3px #3b82f61a;outline:none}.ticker-input::placeholder{color:#9ca3af;color:var(--text-muted)}.search-button{background:#27ae60;background:var(--input-focus);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:1rem;font-weight:600;padding:.875rem 2rem;transition:all .2s ease;white-space:nowrap}.search-button:hover:not(:disabled){background:#2563eb;box-shadow:0 4px 12px #3b82f64d;transform:translateY(-1px)}.search-button:disabled{cursor:not-allowed;opacity:.6}.error-message{align-items:center;color:#ef4444;display:flex;font-size:.9rem;gap:.75rem;margin-top:1rem;padding:.875rem 1.25rem}.error-message svg{flex-shrink:0}.stock-data-container{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--shadow);overflow:hidden}.analysis-results .stock-data-container{margin:0}.stock-header{align-items:flex-start;background:linear-gradient(180deg,#fff,#f5f5f5);background:linear-gradient(to bottom,var(--bg-secondary),var(--bg-primary));border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:flex;gap:1.5rem;justify-content:flex-start;padding:1.5rem 2rem}.company-info{flex:0 1 auto;min-width:0}.company-ticker{color:#333;color:var(--text-primary);font-size:2rem;font-weight:700;letter-spacing:-.02em;margin:0 0 .5rem}.company-name{font-size:1.1rem;margin:0 0 .75rem}.company-name,.exchange-badge{color:#374151;color:var(--text-secondary)}.exchange-badge{background:#f8f9fa;background:var(--bg-tertiary);border-radius:4px;display:inline-block;font-size:.75rem;font-weight:600;letter-spacing:.05em;padding:.25rem .75rem;text-transform:uppercase}.price-info{text-align:right}.current-price{color:#333;color:var(--text-primary);font-size:2rem;font-weight:700;letter-spacing:-.02em;margin-bottom:.25rem}.price-change{align-items:flex-end;border-radius:6px;display:inline-flex;flex-direction:column;font-size:1.1rem;font-weight:600;gap:.25rem;padding:.5rem .875rem}.price-change.positive-change{background:#22c55e1a;color:#22c55e}.price-change.negative-change{background:#ef44441a;color:#ef4444}.change-period{font-size:.75rem;font-weight:500;letter-spacing:.05em;opacity:.8;text-transform:uppercase}.metrics-summary{grid-gap:1.5rem;border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));padding:2rem}.metric-card{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;display:flex;flex-direction:column;gap:.5rem;padding:1.25rem;transition:all .2s ease}.metric-card:hover{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 4px 12px #3b82f61a;transform:translateY(-2px)}.metric-label{color:#374151;color:var(--text-secondary);font-size:.8rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.metric-value{color:#333;color:var(--text-primary);font-size:1.25rem;font-weight:700}.analysis-tabs{align-items:center;background:#0000;border-bottom:2px solid #e1e8ed;border-bottom:2px solid var(--border-color);display:flex!important;gap:0;min-height:50px;overflow-x:auto;padding:0}.tab-button{background:#0000;border:none;border-bottom:3px solid #0000;color:#374151;color:var(--text-secondary);cursor:pointer;font-size:.95rem;font-weight:600;margin-bottom:-2px;padding:1rem 1.5rem;position:relative;transition:all .2s ease;white-space:nowrap}.tab-button:hover{color:#333;color:var(--text-primary)}.tab-button.active,.tab-button:hover{background:#f8f9fa;background:var(--bg-tertiary)}.tab-button.active{border-bottom-color:#27ae60;border-bottom-color:var(--input-focus);color:#27ae60;color:var(--input-focus)}.tab-content{min-height:400px;padding:2rem}.overview-content{display:flex;flex-direction:column;gap:2rem}.info-section{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.info-section h3{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);color:#333;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1.25rem;padding-bottom:.75rem}.info-grid,.performance-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(250px,1fr))}.info-item,.perf-item{display:flex;flex-direction:column;gap:.5rem}.info-label,.perf-label{color:#374151;color:var(--text-secondary);font-size:.85rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.info-value,.perf-value{color:#333;color:var(--text-primary);font-size:1rem;font-weight:600}.company-description{color:#374151;color:var(--text-secondary);font-size:.95rem;line-height:1.7}.fundamentals-content{display:flex;flex-direction:column;gap:2rem}.fundamentals-section{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;padding:1.5rem}.fundamentals-section h3{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);color:#333;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 1.25rem;padding-bottom:.75rem}.fundamentals-grid{grid-gap:1.25rem;display:grid;gap:1.25rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr))}.fund-item{background:#fff;background:var(--bg-secondary);border-radius:6px;display:flex;flex-direction:column;gap:.5rem;padding:1rem}.fund-label{color:#374151;color:var(--text-secondary);font-size:.8rem;font-weight:500;letter-spacing:.05em;text-transform:uppercase}.fund-value{color:#333;color:var(--text-primary);font-size:1.15rem;font-weight:700}.fundamentals-table-container{border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;margin-top:1rem;overflow-x:auto}.fundamentals-table{background:#fff;background:var(--bg-secondary);border-collapse:collapse;width:100%}.fundamentals-table thead{background:#f8f9fa;background:var(--bg-tertiary);border-bottom:2px solid #e1e8ed;border-bottom:2px solid var(--border-color)}.fundamentals-table th{color:#374151;color:var(--text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.05em;padding:1rem;text-align:left;text-transform:uppercase}.fundamentals-table tbody tr{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);transition:background-color .2s ease}.fundamentals-table tbody tr:last-child{border-bottom:none}.fundamentals-table tbody tr:hover{background:#f8f9fa;background:var(--bg-tertiary)}.fundamentals-table td{font-size:.95rem;padding:1rem}.fundamentals-table .metric-name{color:#333;color:var(--text-primary);font-weight:600;width:30%}.fundamentals-table .metric-value{color:#27ae60;color:var(--input-focus);font-size:1.05rem;font-weight:700;width:25%}.fundamentals-table .metric-desc{color:#374151;color:var(--text-secondary);font-size:.85rem;width:45%}.no-data-message{align-items:center;display:flex;flex-direction:column;justify-content:center}.no-data-message svg{color:#9ca3af;color:var(--text-muted);margin-bottom:1rem}.no-data-message h3{border:none;color:#333;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin-bottom:.75rem;padding:0}.no-data-message p{font-size:.95rem;line-height:1.6;margin-bottom:.5rem}.no-data-message ul{list-style:none;padding:0}.no-data-message ul li{font-size:.9rem;padding:.5rem 0 .5rem 1.5rem;position:relative}.no-data-message ul li:before{color:#27ae60;color:var(--input-focus);content:"→";font-weight:700;left:0;position:absolute}.data-notice{align-items:center;background:#3b82f60d;border:1px solid #3b82f633;border-radius:8px;color:#374151;color:var(--text-secondary);display:flex;font-size:.85rem;gap:.75rem;line-height:1.5;padding:1rem 1.25rem}.data-notice svg{color:#27ae60;color:var(--input-focus);flex-shrink:0}.chart-content{display:flex;flex-direction:column;gap:1.5rem}.period-selector{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;display:flex;flex-wrap:wrap;gap:.5rem;padding:.75rem}.period-button{background:#0000;border:1px solid #0000;border-radius:6px;color:#374151;color:var(--text-secondary);cursor:pointer;font-size:.85rem;font-weight:600;padding:.5rem 1rem;transition:all .2s ease}.period-button:hover{background:#f8f9fa;background:var(--bg-tertiary);color:#333;color:var(--text-primary)}.period-button.active{background:#27ae60;background:var(--input-focus);border-color:#27ae60;border-color:var(--input-focus);color:#fff}.chart-container{background:#f5f5f5;background:var(--bg-primary);padding:1.5rem}.price-chart{display:block;height:auto;width:100%}.chart-info{border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);display:flex;gap:2rem;margin-top:1.5rem;padding-top:1.5rem}.chart-stat{display:flex;flex-direction:column;gap:.25rem}.stat-label{font-size:.8rem;letter-spacing:.05em;text-transform:uppercase}.stat-value{font-size:1.1rem}.dividends-content{display:flex;flex-direction:column;gap:1.5rem}.dividends-summary h3{color:#333;color:var(--text-primary);font-size:1.1rem;font-weight:600;margin:0 0 .5rem}.summary-text{color:#374151;color:var(--text-secondary);font-size:.9rem}.dividends-table-container{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;max-height:600px;overflow:hidden;overflow-y:auto}.dividends-table{border-collapse:collapse;width:100%}.dividends-table thead{background:#fff;background:var(--bg-secondary);position:-webkit-sticky;position:sticky;top:0;z-index:10}.dividends-table th{border-bottom:2px solid #e1e8ed;border-bottom:2px solid var(--border-color);color:#374151;color:var(--text-secondary);font-size:.85rem;font-weight:600;letter-spacing:.05em;padding:1rem 1.5rem;text-align:left;text-transform:uppercase}.dividends-table td{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);color:#333;color:var(--text-primary);padding:1rem 1.5rem}.dividends-table tbody tr:hover{background:#f8f9fa;background:var(--bg-tertiary)}.dividend-amount{color:#27ae60;color:var(--input-focus);font-weight:600}.no-data-message{color:#374151;color:var(--text-secondary);font-size:1rem;padding:3rem 2rem;text-align:center}.positive-change{color:#22c55e!important}.negative-change{color:#ef4444!important}@media (max-width:1024px){.stock-header{flex-direction:column;gap:1.5rem}.price-info{text-align:left}.price-change,.price-info{align-items:flex-start}.metrics-summary{grid-template-columns:repeat(2,1fr)}}@media (max-width:768px){.stock-analysis{padding:1rem}.stock-search-container{padding:1.5rem}.search-bar{flex-direction:column}.search-button{width:100%}.company-ticker{font-size:1.5rem}.current-price{font-size:2rem}.metrics-summary{gap:1rem;grid-template-columns:1fr}.analysis-tabs{padding:0 1rem}.tab-button{font-size:.85rem;padding:.875rem 1rem}.tab-content{padding:1.5rem 1rem}.fundamentals-grid,.info-grid,.performance-grid{grid-template-columns:1fr}.period-selector{justify-content:center}.dividends-table td,.dividends-table th{font-size:.85rem;padding:.75rem 1rem}}.source-selector{grid-gap:.75rem;display:grid;gap:.75rem;grid-template-columns:repeat(2,1fr);margin-bottom:.5rem}.source-btn{align-items:center;background:var(--card-bg);border:2px solid #e1e8ed;border:2px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);cursor:pointer;display:flex;font-size:.95rem;font-weight:600;gap:.5rem;justify-content:center;padding:1rem 1.25rem;transition:all .2s ease}.source-btn:hover{background:var(--hover-bg);transform:translateY(-1px)}.source-btn.active,.source-btn:hover{border-color:#27ae60;border-color:var(--input-focus)}.source-btn.active{background:#27ae60;background:var(--input-focus);box-shadow:0 2px 8px #3b82f64d;color:#fff}.source-icon{font-size:1.25rem}.source-label{font-weight:600}.subreddit-selector-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(auto-fit,minmax(120px,1fr));margin-bottom:.5rem}.subreddit-btn{align-items:center;background:var(--card-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);cursor:pointer;display:flex;font-size:.85rem;font-weight:500;gap:.4rem;justify-content:center;padding:.65rem .75rem;transition:all .2s ease}.subreddit-btn:hover{background:var(--hover-bg)}.subreddit-btn.active,.subreddit-btn:hover{border-color:#27ae60;border-color:var(--input-focus)}.subreddit-btn.active{background:#27ae60;background:var(--input-focus);color:#fff}.subreddit-icon{font-size:1rem}.subreddit-label{font-size:.85rem;font-weight:600}.period-selector-grid{grid-gap:.5rem;display:grid;gap:.5rem;grid-template-columns:repeat(4,1fr);margin-bottom:.5rem}.period-btn{background:var(--card-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#333;color:var(--text-primary);cursor:pointer;font-size:.85rem;font-weight:600;padding:.75rem .5rem;transition:all .2s ease}.period-btn:hover{background:var(--hover-bg)}.period-btn.active,.period-btn:hover{border-color:#27ae60;border-color:var(--input-focus)}.period-btn.active{background:#27ae60;background:var(--input-focus);color:#fff}.period-btn:disabled{cursor:not-allowed;opacity:.5}.stock-search-input-group{display:flex;flex-direction:column}.stock-search-input-with-suggest .settings-input{font-size:16px;padding:.9rem 1rem}.ticker-suggestions li span:last-child{max-width:75%;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.discussions-loading-state{align-items:center;color:#374151;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem}.discussions-loading-state .spinner{animation:spin .8s linear infinite;border:3px solid #e1e8ed;border-top-color:#27ae60;border:3px solid var(--border-color);border-radius:50%;border-top-color:var(--input-focus);height:40px;margin-bottom:1rem;width:40px}.discussions-loading-state p{font-size:.95rem}.discussions-error-state{align-items:center;color:#374151;color:var(--text-secondary);display:flex;flex-direction:column;justify-content:center;padding:4rem 2rem;text-align:center}.discussions-error-state svg{color:#ef4444;color:var(--error-color,#ef4444);margin-bottom:1rem}.discussions-error-state p{font-size:1rem;margin-bottom:1.5rem}.retry-button{background:#27ae60;background:var(--input-focus);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.95rem;font-weight:600;padding:.75rem 1.5rem;transition:opacity .2s ease}.retry-button:hover{opacity:.9}.discussions-empty-state{align-items:center;color:#374151;color:var(--text-secondary);display:flex;font-size:1rem;justify-content:center;padding:4rem 2rem}.discussions-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(3,1fr);margin-bottom:2rem;overflow:hidden;padding:0 1.5rem}.discussion-card{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;color:#333;color:var(--text-primary);cursor:pointer;display:flex;flex-direction:column;min-width:0;overflow:hidden;padding:1.5rem;text-decoration:none;transition:all .2s ease}.discussion-card:hover{background:#f8f9fa;background:var(--bg-tertiary);border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 4px 12px #0000001a;transform:translateY(-2px)}.discussion-card-header{margin-bottom:.75rem}.discussion-meta{align-items:center;color:#374151;color:var(--text-secondary);display:flex;font-size:.85rem;gap:.5rem}.discussion-author{font-weight:600}.discussion-separator{opacity:.5}.discussion-time{opacity:.8}.sentiment-badge{border-radius:12px;font-size:.75rem;font-weight:600;padding:.15rem .5rem;text-transform:uppercase}.sentiment-bullish{background:#22c55e26;color:#22c55e}.sentiment-bearish{background:#ef444426;color:#ef4444}.discussion-title{color:#333;color:var(--text-primary);font-size:1.1rem;font-weight:600;line-height:1.4;margin:0 0 .75rem}.discussion-preview,.discussion-title{-webkit-line-clamp:3;line-clamp:3;-webkit-box-orient:vertical;display:-webkit-box;overflow:hidden;overflow-wrap:break-word;text-overflow:ellipsis;word-break:break-word}.discussion-preview{color:#374151;color:var(--text-secondary);font-size:.9rem;line-height:1.5;margin:0 0 1rem}.discussion-card-footer{align-items:center;border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);display:flex;justify-content:space-between;margin-top:auto;padding-top:1rem}.discussion-stats{display:flex;gap:1.25rem}.discussion-stat{align-items:center;color:#374151;color:var(--text-secondary);display:flex;font-size:.85rem;gap:.4rem}.discussion-stat svg{opacity:.7}.discussion-stat.upvotes svg{color:#27ae60;color:var(--input-focus)}.discussion-stat.comments svg,.discussion-subreddit{color:#374151;color:var(--text-secondary)}.discussion-subreddit{background:var(--hover-bg);border-radius:12px;font-size:.8rem;font-weight:500;padding:.25rem .75rem}.discussions-footer{border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);display:flex;justify-content:center;margin-top:2rem;padding:2rem 0}.discussions-view-more{align-items:center;background:#27ae60;background:var(--input-focus);border-radius:8px;color:#fff;display:inline-flex;font-size:.95rem;font-weight:600;gap:.5rem;padding:.875rem 1.75rem;text-decoration:none;transition:all .2s ease}.discussions-view-more:hover{opacity:.9;transform:translateY(-1px)}.discussions-view-more svg{transition:transform .2s ease}.discussions-view-more:hover svg{transform:translateX(3px)}@media (max-width:1400px){.settings-bubbles-container{gap:.75rem}.settings-bubble{padding:1rem}.subreddit-btn{font-size:.8rem;padding:.55rem .6rem}.subreddit-icon{font-size:.9rem}.subreddit-label{font-size:.8rem}}@media (max-width:1024px){.discussions-grid{gap:1.25rem;grid-template-columns:repeat(auto-fill,minmax(300px,1fr))}.settings-bubbles-container{gap:1rem;grid-template-columns:1fr}.subreddit-selector-grid{grid-template-columns:repeat(2,1fr)}.period-selector-grid{grid-template-columns:repeat(4,1fr)}}@media (max-width:768px){.discussions-grid{gap:1rem;grid-template-columns:1fr}.discussion-card{padding:1.25rem}.discussion-title{font-size:1rem}.discussions-footer{padding:1.5rem 0}.subreddit-selector-grid{grid-template-columns:1fr}.period-selector-grid{gap:.4rem;grid-template-columns:repeat(4,1fr)}.period-btn{font-size:.8rem;padding:.625rem .25rem}}.holdings-grid{display:flex;flex-direction:column;gap:.75rem;margin:1rem 0}.holdings-grid .holding-row{grid-gap:.75rem;align-items:center;display:grid;gap:.75rem;grid-template-columns:40px 1fr 150px 40px}.holding-number{align-items:center;background:#f8f9fa;background:var(--bg-tertiary);border-radius:50%;color:#374151;color:var(--text-secondary);display:flex;font-size:.9rem;font-weight:600;height:32px;justify-content:center;width:32px}.holdings-grid .symbol-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#333;color:var(--text-primary);font-family:Courier New,monospace;font-size:1rem;font-weight:600;padding:.75rem;text-transform:uppercase}.holdings-grid .symbol-input:focus{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 0 0 2px #10b9811a;outline:none}.allocation-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#333;color:var(--text-primary);font-size:1rem;padding:.75rem}.allocation-input:focus{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 0 0 2px #10b9811a;outline:none}.remove-btn{background:#0000;border:none;border-radius:50%;color:#374151;color:var(--text-secondary);cursor:pointer;font-size:1.2rem;height:32px;transition:all .2s ease;width:32px}.remove-btn:hover:not(:disabled){background:#ef44441a;color:#ef4444}.remove-btn:disabled{cursor:not-allowed;opacity:.3}.add-holding-btn{border:1px dashed #e1e8ed;border:1px dashed var(--border-color);color:#374151;color:var(--text-secondary);margin-top:.5rem;transition:all .2s ease}.add-holding-btn:hover{background:#27ae60;border-color:#27ae60;border-style:solid;color:#fff}.quick-portfolios{background:#f8f9fa;background:var(--bg-tertiary);border-radius:8px;margin-top:1.5rem;padding:1rem}.quick-portfolios h4{color:#374151;color:var(--text-secondary);font-size:.9rem;font-weight:600;margin-bottom:.75rem}.template-buttons{display:flex;flex-wrap:wrap;gap:.75rem}.template-buttons button{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#333;color:var(--text-primary);cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s ease}.template-buttons button:hover{background:#27ae60;border-color:#27ae60;color:#fff;transform:translateY(-1px)}.params-grid{grid-gap:1.5rem;display:grid;gap:1.5rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:1rem 0}.param-group{display:flex;flex-direction:column;gap:.5rem}.param-group label{color:#333;color:var(--text-primary);font-size:.9rem;font-weight:600}.param-group input,.param-group select{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#333;color:var(--text-primary);font-size:1rem;padding:.75rem}.param-group input:focus,.param-group select:focus{border-color:#27ae60;border-color:var(--input-focus);box-shadow:0 0 0 2px #10b9811a;outline:none}.checkbox-group{justify-content:center}.checkbox-group label{align-items:center;cursor:pointer;display:flex;gap:.5rem}.checkbox-group input[type=checkbox]{cursor:pointer;height:18px;width:18px}.run-simulation-btn{background:linear-gradient(135deg,#10b981,#059669);border:none;border-radius:8px;box-shadow:0 4px 12px #10b9814d;color:#fff;cursor:pointer;font-size:1.1rem;font-weight:600;margin-top:1.5rem;padding:1rem 2rem;transition:all .3s ease}.run-simulation-btn:hover:not(:disabled){background:linear-gradient(135deg,#059669,#047857);box-shadow:0 6px 16px #10b98166;transform:translateY(-2px)}.run-simulation-btn:disabled{cursor:not-allowed;opacity:.6;transform:none}.error-message{background:#ef44441a;border:1px solid #ef44444d;border-radius:8px;color:#dc2626;margin:1rem 0;padding:1rem}.results-section{margin-top:2rem}.results-section h3{color:#333;color:var(--text-primary);font-size:1.5rem;margin-bottom:1.5rem}.stats-grid{grid-gap:1rem;display:grid;gap:1rem;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));margin:1.5rem 0}.stat-card{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;padding:1.25rem;text-align:center}.stat-label{color:#374151;color:var(--text-secondary);font-size:.85rem;font-weight:500;margin-bottom:.5rem}.stat-value{color:#333;color:var(--text-primary);font-size:1.5rem;font-weight:700}.stat-value.success{color:#10b981}.stat-value.warning{color:#ef4444}.chart-container{border-radius:8px;margin:0;padding:.875rem}.chart-container h4{font-size:1.1rem;margin:0 0 .625rem}.chart-description{margin-bottom:1rem}.portfolio-stats{background:#f8f9fa;background:var(--bg-tertiary);border-radius:8px;margin-top:2rem;padding:1.5rem}.portfolio-stats h4{color:#333;color:var(--text-primary);font-size:1.1rem;margin-bottom:1rem}.stats-list{display:flex;flex-direction:column;gap:.75rem}.stat-row{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:flex;justify-content:space-between;padding:.5rem 0}.stat-row:last-child{border-bottom:none}.stat-row span:first-child{color:#374151;color:var(--text-secondary);font-size:.95rem}.stat-row span:last-child{color:#333;color:var(--text-primary);font-size:.95rem;font-weight:600}@media (max-width:768px){.holding-row{grid-template-columns:1fr 100px 32px}.holding-number{display:none}.params-grid,.stats-grid{grid-template-columns:1fr}.template-buttons{flex-direction:column}}@keyframes ask-ai-nudge{0%{box-shadow:0 0 0 0 #667eea00;transform:scale(1)}6%{box-shadow:0 0 0 3px #667eea4d;transform:scale(1.12)}12%{box-shadow:0 0 0 5px #667eea1a;transform:scale(1.06)}18%{box-shadow:0 0 0 3px #667eea38;transform:scale(1.1)}26%{box-shadow:0 0 0 0 #667eea00;transform:scale(1)}to{box-shadow:0 0 0 0 #667eea00;transform:scale(1)}}.ask-ai-btn{align-items:center;animation:ask-ai-nudge 5s ease-in-out 3s infinite;background:linear-gradient(135deg,#667eea1a,#764ba21a);border:1px solid #667eea59;border-radius:20px;color:#667eea;cursor:pointer;display:inline-flex;flex-shrink:0;font-size:13px;font-weight:600;gap:6px;padding:6px 14px;transition:all .25s ease;white-space:nowrap}.ask-ai-btn:hover{animation-play-state:paused;background:linear-gradient(135deg,#667eea33,#764ba233);border-color:#667eea;box-shadow:0 2px 8px #667eea40;transform:translateY(-1px)}.ask-ai-btn:active{transform:translateY(0)}.ask-ai-icon{font-size:14px}.ask-ai-label{letter-spacing:.02em}.results-summary-header{align-items:center;display:flex;flex-wrap:wrap;gap:12px;justify-content:flex-start;margin-bottom:.25rem}.results-summary-header h3{margin:0}.widget-context-badge{align-items:center;background:#ffffff2e;border-radius:10px;display:inline-flex;font-size:.7rem;font-weight:500;gap:4px;margin-left:4px;padding:2px 8px;white-space:nowrap}.widget-quick-prompts{display:flex;flex-direction:column;gap:8px;margin-top:16px;padding:0 4px}.quick-prompt-chip{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:10px;color:#333;color:var(--text-primary);cursor:pointer;display:block;font-size:13px;font-weight:500;padding:10px 14px;text-align:left;transition:all .2s ease;width:100%}.quick-prompt-chip:hover:not(:disabled){background:linear-gradient(135deg,#667eea14,#764ba214);border-color:#667eea;color:#667eea;transform:translateX(4px)}.quick-prompt-chip:disabled{cursor:not-allowed;opacity:.5}.widget-welcome-context{color:#374151;color:var(--text-secondary);font-size:.88rem;line-height:1.5}.ai-widget-button{align-items:center;animation:widget-appear .3s cubic-bezier(.4,0,.2,1);background:linear-gradient(135deg,#667eea,#764ba2);border:none;border-radius:50%;bottom:20px;box-shadow:0 4px 12px #667eea66;cursor:pointer;display:flex;height:60px;justify-content:center;position:fixed;right:20px;transition:all .3s cubic-bezier(.4,0,.2,1);width:60px;z-index:9999}.ai-widget-button:hover{box-shadow:0 6px 16px #667eea99;transform:scale(1.1)}.ai-widget-button .widget-icon{font-size:1.8rem}@keyframes widget-appear{0%{transform:scale(.19)}to{transform:scale(1)}}@keyframes widget-close{0%{transform:scale(1)}to{transform:scale(.19)}}.ai-widget-sidebar{animation:slide-in-right .3s cubic-bezier(.4,0,.2,1);background:#fff;background:var(--bg-secondary);border-left:1px solid #e1e8ed;border-left:1px solid var(--border-color);bottom:0;display:flex;flex-direction:column;position:fixed;right:0;top:0;width:550px;z-index:1000}.ai-widget-sidebar.closing{animation:slide-out-right .3s cubic-bezier(.4,0,.2,1)}@keyframes slide-in-right{0%{transform:translateX(100%)}to{transform:translateX(0)}}@keyframes slide-out-right{0%{transform:translateX(0)}to{transform:translateX(100%)}}.widget-header{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;flex-shrink:0;justify-content:space-between;padding:12px 16px;-webkit-user-select:none;user-select:none}.widget-header,.widget-title{align-items:center;display:flex}.widget-title{font-size:.95rem;font-weight:600;gap:8px}.widget-icon-small{font-size:1.2rem}.widget-controls{display:flex;gap:8px}.widget-control-btn{align-items:center;background:#fff3;border:none;border-radius:6px;cursor:pointer;display:flex;font-size:.9rem;height:28px;justify-content:center;position:relative;transition:all .2s ease;width:28px}.widget-control-btn:hover{background:#ffffff4d;transform:translateY(-2px)}.widget-control-btn:after,.widget-control-btn:before{content:"";opacity:0;pointer-events:none;position:absolute;transition:opacity .2s ease 0s,visibility 0s linear .2s;visibility:hidden}.widget-control-btn:before{background:#fff;border-radius:6px;box-shadow:0 2px 8px #00000026;color:#1a1a2e;content:attr(aria-label);font-size:.75rem;margin-top:8px;padding:6px 10px;white-space:nowrap}.widget-control-btn:after,.widget-control-btn:before{left:50%;top:100%;transform:translateX(-50%);z-index:10000}.widget-control-btn:after{border:6px solid;border-color:#0000 #0000 #fff;content:"";margin-top:2px}.widget-control-btn:hover:after,.widget-control-btn:hover:before{opacity:1;transition:opacity .2s ease .6s,visibility 0s linear .6s;visibility:visible}.chat-history-dropdown{background:#f5f5f5;background:var(--bg-primary);border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);flex-shrink:0;max-height:300px;overflow-y:auto}.chat-history-header{color:#374151;color:var(--text-secondary);font-size:12px;font-weight:600;padding:12px 16px;text-transform:uppercase}.chat-history-item{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);cursor:pointer;padding:12px 16px;transition:background .2s}.chat-history-item:hover{background:#f8f9fa;background:var(--bg-tertiary)}.chat-history-preview{color:#333;color:var(--text-primary);font-size:13px;margin-bottom:4px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.chat-history-time{font-size:11px}.chat-history-empty{color:#374151;color:var(--text-secondary);font-size:13px;padding:16px;text-align:center}.widget-messages{display:flex;flex:1 1;flex-direction:column;gap:12px;overflow-y:auto;padding:16px}.widget-welcome{color:#374151;color:var(--text-secondary);padding:20px;text-align:center}.widget-welcome p{margin:8px 0}.widget-welcome ul{margin:12px auto;max-width:200px;text-align:left}.widget-message{animation:slideIn .3s ease;max-width:85%}.widget-message.user-message{align-self:flex-end}.widget-message.assistant-message{align-self:flex-start}.message-content{border-radius:12px;font-size:.9rem;line-height:1.5;padding:10px 14px}.user-message .message-content{background:linear-gradient(135deg,#667eea,#764ba2);color:#fff}.assistant-message .message-content{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);color:#333;color:var(--text-primary)}.message-charts{display:flex;flex-direction:column;gap:6px;margin-top:8px}.mini-chart-indicator{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#374151;color:var(--text-secondary);font-size:.85rem;padding:6px 10px}.typing-indicator{display:flex;gap:4px;padding:10px 14px}.typing-indicator span{animation:bounce 1.4s ease-in-out infinite;background:#9ca3af;background:var(--text-muted);border-radius:50%;height:8px;width:8px}.typing-indicator span:nth-child(2){animation-delay:.2s}.typing-indicator span:nth-child(3){animation-delay:.4s}@keyframes bounce{0%,80%,to{transform:translateY(0)}40%{transform:translateY(-8px)}}.widget-input-container{background:#fff;background:var(--bg-secondary);border-radius:0 0 12px 12px;border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);display:flex;gap:8px;padding:12px}.widget-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.9rem;padding:8px 12px;resize:none}.widget-input:focus{border-color:#667eea;outline:none}.widget-send-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #667eea;border-radius:50%;color:#fff;cursor:pointer;display:flex;height:44px;justify-content:center;padding:0;transition:all .2s ease;width:44px}.widget-send-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.widget-send-btn:disabled{cursor:not-allowed;opacity:.5}.ai-assistant-wrapper{margin-bottom:2rem;position:relative}.ai-assistant-section{background:#fff;background:var(--bg-secondary);border-radius:8px;box-shadow:0 4px 6px #0000001a;box-shadow:0 4px 6px var(--shadow);display:flex;flex-direction:column;height:calc(100vh - 2rem);overflow:hidden;position:relative;width:100%}.ai-section-header{background:linear-gradient(135deg,#2c3e50,#3498db);background:var(--gradient-primary);color:#fff;padding:2rem;position:relative;text-align:center}.ai-section-title h2{color:#fff;font-size:1.8rem;font-weight:600;margin:0 0 .5rem}.beta-badge{background:#ffffff38;border:1px solid #ffffff59;border-radius:4px;color:#fff;display:inline-block;font-size:.55rem;font-weight:700;letter-spacing:.08em;margin-left:8px;padding:3px 8px;position:relative;text-transform:uppercase;top:-2px;vertical-align:middle}.beta-badge-sm{font-size:.5rem;margin-left:6px;padding:2px 6px}.beta-badge-card{background:linear-gradient(135deg,#06b6d4,#0891b2);border:none;color:#fff;font-size:.55rem;margin-left:10px;padding:3px 8px;top:-1px}.beta-badge-nav{background:#667eea33;border:1px solid #667eea59;color:#667eea;font-size:.45rem;margin-left:6px;padding:1px 5px;top:-1px}.beta-notice{align-items:flex-start;background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-left:3px solid #f0ad4e;border-radius:8px;color:#374151;color:var(--text-secondary);display:flex;font-size:.88rem;gap:10px;line-height:1.5;margin:24px auto 0;max-width:500px;padding:14px 18px;text-align:left}.beta-notice-icon{flex-shrink:0;font-size:1.3rem;margin-top:1px}.beta-notice p{margin:0}.beta-notice strong{color:#333;color:var(--text-primary)}.ai-section-subtitle{color:#fff;font-size:1.1rem;margin:0;opacity:.9}.ai-section-controls{align-items:center;display:flex;gap:12px}.usage-indicator{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:#374151;color:var(--text-secondary);font-size:.85rem;padding:8px 16px}.usage-text{font-weight:500}.clear-btn{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);cursor:pointer;font-size:.95rem;padding:10px 20px;transition:all .2s ease}.clear-btn:hover:not(:disabled){background:#f8f9fa;background:var(--bg-tertiary);border-color:#667eea}.clear-btn:disabled{cursor:not-allowed;opacity:.5}.new-chat-btn{align-items:center;background:#fff;background:var(--bg-secondary);border-radius:8px;cursor:pointer;display:flex;height:40px;justify-content:center;padding:0;position:relative;transition:all .2s ease;width:40px;z-index:10}.new-chat-btn,.new-chat-btn:after{border:1px solid #e1e8ed;border:1px solid var(--border-color);color:#333;color:var(--text-primary)}.new-chat-btn:after{background:#f8f9fa!important;background:var(--bg-tertiary)!important;border-radius:6px;box-shadow:0 4px 12px #0000001a;box-shadow:0 4px 12px var(--shadow);content:attr(title);font-size:.85rem;font-weight:500;opacity:0;padding:.5rem .75rem;pointer-events:none;position:absolute;right:calc(100% + 8px);top:50%;transform:translateY(-50%);transition:opacity .2s ease,visibility .2s ease;visibility:hidden;white-space:nowrap;z-index:1001}.new-chat-btn:hover:not(:disabled):after{opacity:1;visibility:visible}.new-chat-btn svg{stroke:#333;stroke:var(--text-primary);pointer-events:none;transition:stroke .2s ease}.new-chat-btn:hover:not(:disabled){background:#667eea;border-color:#667eea}.new-chat-btn:hover:not(:disabled) svg{stroke:#fff}.new-chat-btn:disabled{cursor:not-allowed;opacity:.5}.new-chat-btn:disabled svg{stroke:#374151;stroke:var(--text-secondary)}.ai-section-content{display:flex;flex:1 1;flex-direction:row;margin:0 auto;overflow:hidden;padding:0;position:relative;width:100%}@keyframes slideInFromLeft{0%{opacity:0;transform:translateX(-100%)}to{opacity:1;transform:translateX(0)}}.chat-history-sidebar{align-self:stretch;animation:slideInFromLeft .2s ease;background:#fff;background:var(--bg-secondary);border-right:1px solid #e1e8ed;border-right:1px solid var(--border-color);box-shadow:2px 0 12px #00000014;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative;width:300px}.chat-history-header{align-items:center;background:linear-gradient(135deg,#667eea1f,#764ba214);border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);display:flex;flex-shrink:0;justify-content:space-between;padding:18px 16px 14px}.chat-history-header h3{color:#333;color:var(--text-primary);font-size:.95rem;font-weight:600;letter-spacing:.02em;margin:0;opacity:.8;text-transform:uppercase}.close-history-btn{align-items:center;background:#0000;border:none;border-radius:6px;color:#374151;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.3rem;height:28px;justify-content:center;line-height:1;padding:0;transition:all .15s ease;width:28px}.close-history-btn:hover{background:#667eea26;color:#333;color:var(--text-primary)}.chat-history-list{display:flex;flex:1 1;flex-direction:column;gap:4px;overflow-y:auto;padding:10px 8px;scrollbar-color:#e1e8ed #0000;scrollbar-color:var(--border-color) #0000;scrollbar-width:thin}.chat-history-list::-webkit-scrollbar{width:4px}.chat-history-list::-webkit-scrollbar-thumb{background:#e1e8ed;background:var(--border-color);border-radius:4px}.chat-history-item{border-radius:10px;overflow:hidden;position:relative}.chat-history-item-btn{background:#0000;border:1px solid #0000;border-radius:10px;cursor:pointer;display:block;padding:11px 14px;text-align:left;transition:all .15s ease;width:100%}.chat-history-item:hover .chat-history-item-btn{background:#f8f9fa;background:var(--bg-tertiary);border-color:#e1e8ed;border-color:var(--border-color)}.chat-history-item-btn.active{background:linear-gradient(135deg,#667eea2e,#764ba21f);border-color:#667eea8c;border-left:3px solid #667eea;padding-left:11px}.chat-history-item-btn.active:hover{background:linear-gradient(135deg,#667eea3d,#764ba229)}.chat-history-title{color:#333;color:var(--text-primary);font-size:.865rem;font-weight:500;margin-bottom:4px;overflow:hidden;padding-right:48px;text-overflow:ellipsis;white-space:nowrap}.current-indicator{background:#667eea;border-radius:50%;display:inline-block;height:7px;margin-right:6px;position:relative;top:-1px;vertical-align:middle;width:7px}.chat-history-time{color:#374151;color:var(--text-secondary);font-size:.72rem;opacity:.75}.current-label{color:#667eea;font-weight:600;margin-left:4px}.chat-history-item-actions{display:flex;gap:4px;opacity:0;pointer-events:none;position:absolute;right:8px;top:50%;transform:translateY(-50%);transition:opacity .15s ease}.chat-history-item:hover .chat-history-item-actions{opacity:1;pointer-events:auto}.delete-chat-btn,.download-chat-btn{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#374151;color:var(--text-secondary);cursor:pointer;display:flex;flex-shrink:0;height:28px;justify-content:center;padding:0;transition:all .15s ease;width:28px}.download-chat-btn:hover{background:#667eea;border-color:#667eea;color:#fff}.delete-chat-btn:hover{background:#ef4444;border-color:#ef4444;color:#fff}.no-history{color:#374151;color:var(--text-secondary);font-size:.875rem;opacity:.6;padding:48px 20px;text-align:center}.history-footer{border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);flex-shrink:0;padding:8px 10px}.reenable-confirm-btn{background:#0000;border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:7px;color:#374151;color:var(--text-secondary);cursor:pointer;font-size:.75rem;padding:7px 0;transition:all .15s ease;width:100%}.reenable-confirm-btn:hover{background:#667eea0f;border-color:#667eea;color:#667eea}.sources-link-btn{align-items:center;background:#2563eb14;border:1px solid #2563eb59;border-radius:12px;color:#2563eb;cursor:pointer;display:inline-flex;font-size:11px;font-weight:500;gap:4px;line-height:1.4;margin-top:8px;padding:3px 8px;transition:all .15s ease}.sources-link-btn:hover{background:#2563eb29;border-color:#3b82f699;color:#1d4ed8}[data-theme=dark] .sources-link-btn{background:#3b82f61a;border-color:#3b82f659;color:#60a5fa}[data-theme=dark] .sources-link-btn:hover{background:#3b82f633;color:#93c5fd}@keyframes slideInFromRight{0%{opacity:0;transform:translateX(100%)}to{opacity:1;transform:translateX(0)}}.sources-panel{align-self:stretch;animation:slideInFromRight .2s ease;background:#fff;background:var(--bg-secondary);border-left:2px solid #2563eb99;box-shadow:-2px 0 12px #2563eb2e;display:flex;flex-direction:column;flex-shrink:0;overflow:hidden;position:relative;width:260px}.sources-panel-header{align-items:center;background:linear-gradient(135deg,#2563eb38,#3b82f626);border-bottom:1px solid #2563eb4d;display:flex;flex-shrink:0;justify-content:space-between;padding:16px 14px 12px}.sources-panel-title{color:#2563eb;font-size:.9rem;font-weight:700;letter-spacing:.06em;opacity:1;text-transform:uppercase}.sources-panel-close{align-items:center;background:#0000;border:none;border-radius:6px;color:#374151;color:var(--text-secondary);cursor:pointer;display:flex;font-size:1rem;height:26px;justify-content:center;padding:0;transition:all .15s ease;width:26px}.sources-panel-close:hover{background:#2563eb26;color:#60a5fa}.sources-panel-list{display:flex;flex:1 1;flex-direction:column;gap:6px;overflow-y:auto;padding:10px 8px;scrollbar-color:#e1e8ed #0000;scrollbar-color:var(--border-color) #0000;scrollbar-width:thin}.sources-panel-item{background:#2563eb0f;border:1px solid #2563eb38;border-radius:8px;padding:9px 10px}[data-theme=dark] .sources-panel-item{background:#3b82f61f;border-color:#3b82f647}.sources-panel-item-label{align-items:center;color:#2563eb;display:flex;font-size:10px;font-weight:600;gap:4px;letter-spacing:.04em;margin-bottom:4px;text-transform:uppercase}[data-theme=dark] .sources-panel-item-label,[data-theme=dark] .sources-panel-title,[data-theme=dark] .sources-widget-popover-header{color:#60a5fa}[data-theme=dark] .sources-panel-link:hover .sources-panel-link-title,[data-theme=dark] .sources-panel-result-count{color:#93c5fd}.sources-panel-item-query{color:#333;color:var(--text-primary);font-size:12px;font-style:italic;line-height:1.45;margin-bottom:4px}.sources-panel-result-count{background:#2563eb26;border-radius:4px;color:#3b82f6;font-size:9px;font-weight:700;letter-spacing:.02em;margin-left:auto;padding:1px 5px}.sources-panel-links{border-top:1px solid #2563eb2e;display:flex;flex-direction:column;gap:3px;margin-top:6px;padding-top:6px}.sources-panel-link{align-items:flex-start;background:#ffffff08;border:1px solid #0000;border-radius:5px;display:flex;gap:4px;justify-content:space-between;padding:4px 6px;text-decoration:none;transition:all .15s ease}.sources-panel-link:hover{background:#2563eb17;border-color:#2563eb47}.sources-panel-link svg{color:#3b82f6;flex-shrink:0;margin-top:2px;opacity:.7}.sources-panel-link-title{-webkit-line-clamp:2;-webkit-box-orient:vertical;color:#374151;color:var(--text-secondary);display:-webkit-box;font-size:11px;line-height:1.4;overflow:hidden}.sources-panel-link:hover .sources-panel-link-title{color:#2563eb}.sources-widget-popover{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #2563eb4d;border-radius:8px;margin-top:8px;overflow:hidden}.sources-widget-popover-header{align-items:center;background:#2563eb14;border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);color:#2563eb;display:flex;font-size:11px;font-weight:600;justify-content:space-between;letter-spacing:.04em;padding:7px 10px;text-transform:uppercase}.sources-widget-popover-header button{background:none;border:none;color:#374151;color:var(--text-secondary);cursor:pointer;font-size:12px;line-height:1;padding:0}.sources-widget-popover-header button:hover{color:#3b82f6}.sources-widget-popover-item{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);padding:7px 10px}.sources-widget-popover-item:last-child{border-bottom:none}.conversation-column{background:#0000;border:none;border-radius:0;display:flex;flex:1 1;flex-direction:column;height:100%;min-height:0;overflow:visible;position:relative;width:100%}.conversation-actions-overlay{display:flex;gap:8px;left:8px;overflow:visible;position:absolute;top:8px;z-index:10001}.action-btn-overlay{align-items:center;background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;box-shadow:0 2px 8px #0000001a;color:#374151;color:var(--text-secondary);cursor:pointer;display:flex;height:32px;justify-content:center;padding:0;position:relative;transition:all .2s ease;width:32px}.action-btn-overlay:after{background:#fff;border:1px solid #0000001a;border-radius:6px;box-shadow:0 4px 12px #00000026;color:#1a1a2e;content:attr(data-tooltip);font-size:.85rem;font-weight:500;left:0;opacity:0;padding:.5rem .75rem;pointer-events:none;position:absolute;top:calc(100% + 8px);transform:translateX(0);transition:opacity .2s ease,visibility .2s ease;transition-delay:0s;visibility:hidden;white-space:nowrap;z-index:10000}.action-btn-overlay:hover:not(:disabled):after{opacity:1;transition-delay:.8s;visibility:visible}.action-btn-overlay:hover:not(:disabled){background:#667eea;border-color:#667eea;box-shadow:0 4px 12px #667eea4d;color:#fff}.action-btn-overlay:hover:not(:disabled) svg{stroke:#fff}.action-btn-overlay:disabled{cursor:not-allowed;opacity:.4}.conversation-messages{display:flex;flex:1 1;flex-direction:column;gap:20px;min-height:0;overflow-y:auto;padding:16px 16px 140px}.conversation-welcome{color:#374151;color:var(--text-secondary);padding:60px 40px;text-align:center}.welcome-icon{font-size:4rem;margin-bottom:20px}.conversation-welcome h3{color:#333;color:var(--text-primary);font-size:1.5rem;margin-bottom:12px}.welcome-examples{margin-top:40px}.examples-title{color:#333;color:var(--text-primary);font-weight:600;margin-bottom:16px}.example-questions{display:flex;flex-direction:column;gap:12px;margin:0 auto;max-width:500px}.example-question{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);cursor:pointer;font-size:.95rem;padding:12px 20px;text-align:left;transition:all .2s ease}.example-question:hover{background:#fff;background:var(--bg-secondary);border-color:#667eea;transform:translateX(4px)}.ai-section-message{animation:slideIn .3s ease;display:flex;gap:12px}.ai-section-message.user-message{flex-direction:row-reverse}.message-avatar{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:1.5rem;height:40px;justify-content:center;width:40px}.user-message .message-avatar{background:linear-gradient(135deg,#667eea,#764ba2)}.assistant-message .message-avatar{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color)}.message-bubble{flex:1 1;max-width:75%}.message-text{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;line-height:1.6;padding:16px}.user-message .message-bubble{flex:0 1 auto;max-width:75%}.user-message .message-text{background:linear-gradient(135deg,#667eea,#764ba2);border:none;color:#fff;display:inline-block;padding:10px 16px;width:auto}.user-message .message-text p{margin:0}.message-text p{margin-bottom:12px}.message-text p:last-child{margin-bottom:0}.message-text h2,.message-text h3,.message-text h4{color:#333;color:var(--text-primary);font-weight:600;margin:16px 0 12px}.assistant-message .message-text h2,.assistant-message .message-text h3,.assistant-message .message-text h4{color:#333;color:var(--text-primary)}.message-text h2{font-size:1.3rem}.message-text h3{font-size:1.15rem}.message-text h4{font-size:1.05rem}.message-text strong{color:inherit;font-weight:700}.message-text em{font-style:italic}.message-text li{line-height:1.6;margin-bottom:8px}.message-charts{grid-gap:16px;display:grid;gap:16px;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));margin-top:16px}.chart-card{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;padding:16px}.chart-card h5{color:#333;color:var(--text-primary);margin-bottom:8px}.chart-description{color:#374151;color:var(--text-secondary);font-size:.9rem;margin-bottom:12px}.chart-placeholder{background:#f8f9fa;background:var(--bg-tertiary);border:2px dashed #e1e8ed;border:2px dashed var(--border-color);border-radius:6px;color:#9ca3af;color:var(--text-muted);padding:40px 20px;text-align:center}.suggested-actions{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;margin-top:16px;padding:12px}.actions-label{color:#374151;color:var(--text-secondary);font-size:.85rem;margin-bottom:8px}.action-button{background:#667eea1a;border:1px solid #667eea;border-radius:6px;color:#667eea;cursor:pointer;display:inline-block;font-size:.85rem;margin:4px;padding:6px 14px;transition:all .2s ease}.action-button:hover{background:#667eea;color:#fff}.message-timestamp{color:#9ca3af;color:var(--text-muted);font-size:.75rem;margin-top:8px}.typing-indicator-large{display:flex;gap:6px;padding:16px}.typing-indicator-large span{animation:bounce 1.4s ease-in-out infinite;background:#9ca3af;background:var(--text-muted);border-radius:50%;height:10px;width:10px}.typing-indicator-large span:nth-child(2){animation-delay:.2s}.typing-indicator-large span:nth-child(3){animation-delay:.4s}.conversation-input-container{background:#fff;background:var(--bg-secondary);border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);display:flex;gap:12px;padding:20px}.conversation-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.95rem;line-height:1.5;padding:12px 16px;resize:none}.conversation-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.conversation-send-btn{align-items:center;background:linear-gradient(135deg,#667eea,#764ba2);border:2px solid #667eea;border-radius:50%;color:#fff;cursor:pointer;display:flex;font-weight:600;height:44px;justify-content:center;padding:0;transition:all .2s ease;width:44px}.conversation-send-btn:hover:not(:disabled){box-shadow:0 4px 12px #667eea66;transform:translateY(-2px)}.conversation-send-btn:disabled{cursor:not-allowed;opacity:.5}.ai-disclaimer-outside{background:#ffc1071a;border:1px solid #ffc1074d;border-radius:8px;bottom:20px;box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--shadow);left:calc(50% + 620px);padding:10px 14px;position:fixed;width:280px;z-index:1000}.disclaimer-text-small{color:#374151;color:var(--text-secondary);font-size:.75rem;line-height:1.4;margin:0}@media (max-width:1520px){.ai-disclaimer-outside{display:none}}.conversation-input-floating{background:#fff;background:var(--bg-secondary);border-top:1px solid #e1e8ed;border-top:1px solid var(--border-color);bottom:0;display:flex;gap:12px;left:0;padding:16px 20px;position:absolute;right:0;z-index:100}.conversation-input-floating .conversation-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;color:#333;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.95rem;line-height:1.5;max-height:150px;min-height:48px;overflow-y:hidden;padding:12px 16px;resize:none;transition:height .1s ease}.conversation-input-floating .conversation-input:focus{border-color:#667eea;box-shadow:0 0 0 3px #667eea1a;outline:none}.conversation-input-floating .conversation-send-btn{align-self:flex-end;flex-shrink:0}.conversation-input-top{background:#fff;background:var(--bg-secondary);border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);border-top:none;box-shadow:0 2px 8px #0000000d;position:-webkit-sticky;position:sticky;top:0;z-index:10}.conversation-messages-below-input{display:flex;flex:1 1;flex-direction:column;gap:20px;overflow-y:auto;padding:24px}.context-column{display:none}.context-card{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;padding:20px}.context-card h4{color:#333;color:var(--text-primary);font-size:1.1rem;margin-bottom:16px}.context-holdings{display:flex;flex-direction:column;gap:8px}.context-holding-item{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;display:flex;justify-content:space-between;padding:10px}.holding-symbol{color:#333;color:var(--text-primary)}.holding-percentage,.holding-symbol{align-items:center;display:flex;font-weight:600}.holding-percentage{color:#667eea}.context-ticker{background:#667eea1a;border-radius:8px;color:#667eea;font-size:1.5rem;font-weight:700;padding:20px;text-align:center}.context-help-list{display:flex;flex-direction:column;gap:10px;list-style:none}.context-help-list li{color:#374151;color:var(--text-secondary);font-size:.9rem;padding-left:24px;position:relative}.context-help-list li:before{color:#667eea;content:"✓";font-weight:700;left:0;position:absolute}.context-disclaimer{background:#ffc1071a;border:1px solid #ffc1074d;border-radius:12px;margin-top:auto;padding:16px}.disclaimer-title{color:#333;color:var(--text-primary);font-size:.9rem;font-weight:600;margin-bottom:8px}.disclaimer-text{color:#374151;color:var(--text-secondary);font-size:.85rem;line-height:1.5}@keyframes slideIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}@media (max-width:1024px){.ai-section-content{grid-template-columns:1fr}.context-column{display:none!important}.message-bubble{max-width:90%}}@media (max-width:768px){.ai-widget-sidebar{width:100vw}.App.ai-sidebar-open{margin-right:0}.ask-ai-btn{font-size:12px;padding:5px 10px}.widget-context-badge{display:none}.ai-assistant-section{padding:12px}.ai-section-header{flex-direction:column;gap:16px}.ai-section-title h2{font-size:1.5rem}.conversation-welcome{padding:40px 20px}.message-charts{grid-template-columns:1fr}.ai-section-content{grid-template-columns:1fr!important}.context-column{display:none!important}}.delete-confirm-backdrop{align-items:center;animation:fadeIn .15s ease;background:#00000073;display:flex;inset:0;justify-content:center;position:fixed;z-index:99999}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.delete-confirm-modal{align-items:center;animation:scaleIn .15s ease;background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:14px;box-shadow:0 20px 60px #0000004d;display:flex;flex-direction:column;gap:10px;padding:28px 28px 22px;width:320px}@keyframes scaleIn{0%{opacity:0;transform:scale(.92)}to{opacity:1;transform:scale(1)}}.delete-confirm-icon{align-items:center;background:#ef44441a;border-radius:50%;color:#ef4444;display:flex;height:48px;justify-content:center;margin-bottom:4px;width:48px}.delete-confirm-title{color:#333;color:var(--text-primary);font-size:1rem;font-weight:600;margin:0}.delete-confirm-body{color:#374151;color:var(--text-secondary);font-size:.85rem;margin:0;text-align:center}.delete-confirm-check{align-items:center;color:#374151;color:var(--text-secondary);cursor:pointer;display:flex;font-size:.82rem;gap:7px;margin-top:4px;-webkit-user-select:none;user-select:none}.delete-confirm-check input[type=checkbox]{accent-color:#667eea;cursor:pointer;flex-shrink:0;height:14px;width:14px}.delete-confirm-actions{display:flex;gap:10px;margin-top:8px;width:100%}.delete-confirm-cancel,.delete-confirm-ok{border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;cursor:pointer;flex:1 1;font-size:.9rem;font-weight:500;padding:9px 0;transition:all .15s ease}.delete-confirm-cancel{background:#f8f9fa;background:var(--bg-tertiary);color:#333;color:var(--text-primary)}.delete-confirm-cancel:hover{background:#fff;background:var(--bg-secondary);border-color:#667eea}.delete-confirm-ok{background:#ef4444;border-color:#ef4444;color:#fff}.delete-confirm-ok:hover{background:#dc2626;border-color:#dc2626}.portfolio-analyzer-input{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;margin-bottom:2rem;padding:2rem}.portfolio-analyzer-input .holding-row{grid-gap:.2rem;align-items:center;background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;display:grid;gap:.2rem;grid-template-columns:120px 78px 1fr 36px;margin-bottom:.15rem;padding:.15rem .3rem}.portfolio-analyzer-input .percentage-input,.portfolio-analyzer-input .symbol-input{background:#fff;background:var(--input-bg);border:1px solid #e1e8ed;border:1px solid var(--input-border);border-radius:4px;box-sizing:border-box;color:#333;color:var(--text-primary);font-family:Segoe UI,Tahoma,Geneva,Verdana,sans-serif;font-size:.8rem;font-weight:400;height:28px;line-height:1;padding:.35rem .5rem;width:100%}.portfolio-analyzer-input .symbol-input{text-transform:uppercase}.portfolio-analyzer-input .remove-holding-btn{grid-column:auto}.analyzer-input-header{align-items:center;display:flex;justify-content:space-between;margin-bottom:1.5rem}.analyzer-input-header h3{color:#333;color:var(--text-primary);font-size:1.25rem;margin:0}.analyzer-buttons{display:flex;gap:.75rem}.import-btn{background:#3498db;background:var(--primary-blue);border:none;border-radius:6px;color:#fff;cursor:pointer;font-size:.9rem;padding:.5rem 1rem;transition:all .2s}.import-btn:hover{background:#2980b9;background:var(--primary-blue-hover);transform:translateY(-1px)}.analyzer-holdings-table{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:8px;overflow:hidden}.analyzer-table-header{background:#f8f9fa;background:var(--bg-tertiary);border-bottom:2px solid #e1e8ed;border-bottom:2px solid var(--border-color);color:#333;color:var(--text-primary);font-weight:600}.analyzer-table-header,.analyzer-table-row{grid-gap:1rem;align-items:center;display:grid;gap:1rem;grid-template-columns:1fr 2fr 1.5fr 2fr 80px;padding:1rem}.analyzer-table-row{border-bottom:1px solid #e1e8ed;border-bottom:1px solid var(--border-color);transition:background .2s}.analyzer-table-row:hover{background:#e8e8e8;background:var(--bg-hover)}.analyzer-table-row:last-child{border-bottom:none}.analyzer-symbol-input,.analyzer-type-select,.analyzer-value-input{background:#f5f5f5;background:var(--bg-primary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#333;color:var(--text-primary);font-size:.95rem;padding:.6rem;transition:all .2s}.analyzer-symbol-input:focus,.analyzer-type-select:focus,.analyzer-value-input:focus{border-color:#3498db;border-color:var(--primary-blue);box-shadow:0 0 0 3px #3b82f61a;outline:none}.analyzer-symbol-input{font-weight:600;text-transform:uppercase}.remove-holding-btn{background:#0000;border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:6px;color:#ef4444;color:var(--error-color);cursor:pointer;font-size:1.1rem;padding:.5rem;transition:all .2s}.remove-holding-btn:hover:not(:disabled){background:#ef44441a;border-color:#ef4444;border-color:var(--error-color)}.remove-holding-btn:disabled{cursor:not-allowed;opacity:.3}.analyzer-action-buttons{display:flex;gap:1rem;justify-content:center;margin-top:1.5rem}.add-holding-btn{background:#f8f9fa;background:var(--bg-tertiary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:5px;color:#333;color:var(--text-primary);cursor:pointer;font-size:.8rem;font-weight:500;padding:.4rem .85rem;transition:all .2s}.add-holding-btn:hover{background:#e8e8e8;background:var(--bg-hover);box-shadow:0 2px 8px #0000001a;box-shadow:0 2px 8px var(--shadow);transform:translateY(-1px)}.analyze-btn{align-items:center;background:linear-gradient(135deg,#2c3e50,#3498db);background:var(--gradient-primary);border:none;border-radius:8px;color:#fff;cursor:pointer;display:flex;font-size:1.1rem;font-weight:600;gap:.5rem;justify-content:center;margin:0 auto;max-width:400px;padding:1rem 2rem;transition:all .2s ease;width:33%}.analyze-btn:hover:not(:disabled){box-shadow:0 6px 20px #3498db4d;transform:translateY(-2px)}.analyze-btn:disabled{box-shadow:none;cursor:not-allowed;opacity:.6;transform:none}.analyzer-results{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;margin-top:2rem;padding:2rem}.results-summary{background:#0000;border-radius:0;box-shadow:none;color:#333;color:var(--text-primary);margin-bottom:1.25rem;padding:0}.results-summary h3{font-size:1.5rem;margin:0 0 .25rem}.total-value{font-size:1.1rem;margin:0}.total-value strong{font-size:1.5rem;font-weight:700}.chart-container{background:#fff;background:var(--bg-secondary);border:1px solid #e1e8ed;border:1px solid var(--border-color);border-radius:12px;box-shadow:0 2px 8px #0000000d;margin-bottom:2rem;padding:2rem}.chart-container h4{align-items:center;color:#333;color:var(--text-primary);display:flex;font-size:1.25rem;font-weight:600;gap:.5rem;margin:0 0 .25rem}@media (max-width:768px){.analyzer-table-header,.analyzer-table-row{gap:.5rem;grid-template-columns:1.5fr 1.5fr 60px;padding:.75rem}.analyzer-symbol-input,.analyzer-type-select,.analyzer-value-input{font-size:.85rem;padding:.5rem}.analyzer-action-buttons{flex-direction:column}.add-holding-btn,.analyze-btn{width:80%}.chart-container{padding:1rem}}.search-spinner{animation:spin .7s linear infinite;border:2px solid #e1e8ed;border-top-color:#27ae60;border:2px solid var(--border-color);border-radius:50%;border-top-color:var(--input-focus);height:18px;width:18px}.stock-loading-overlay{align-items:center;display:flex;justify-content:center;padding:4rem 2rem}.stock-loading-content{align-items:center;display:flex;flex-direction:column;gap:1rem}.stock-loading-spinner{animation:spin .8s linear infinite;border:4px solid #e1e8ed;border-top-color:#27ae60;border:4px solid var(--border-color);border-radius:50%;border-top-color:var(--input-focus);height:48px;width:48px}.stock-loading-text{color:#333;color:var(--text-primary);font-size:1.1rem;margin:0}.stock-loading-subtext{color:#9ca3af;color:var(--text-muted);font-size:.85rem;margin:0}.ticker-suggestions li:hover{background:#f8f9fa!important;background:var(--bg-tertiary)!important}
/*# sourceMappingURL=main.1092335b.css.map*/