:root{--bg-primary: #0a0a0f;--bg-secondary: #14141b;--bg-tertiary: #1c1c26;--bg-elevated: #22222e;--bg-glass: rgba(20, 20, 27, .7);--bg-glass-hover: rgba(28, 28, 38, .85);--text-primary: #ffffff;--text-secondary: #e3e3e6;--text-muted: #8a8a99;--text-subtle: #5a5a66;--accent-primary: #6366f1;--accent-light: #818cf8;--accent-glow: rgba(99, 102, 241, .35);--accent-gradient: linear-gradient(135deg, #6366f1, #a78bfa, #818cf8);--accent-gradient-hover: linear-gradient(135deg, #818cf8, #6366f1, #a78bfa);--success: #10b981;--success-soft: rgba(16, 185, 129, .15);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .15);--warning: #f59e0b;--warning-soft: rgba(245, 158, 11, .15);--info: #3b82f6;--border-subtle: rgba(99, 102, 241, .1);--border-default: rgba(99, 102, 241, .15);--border-hover: rgba(99, 102, 241, .3);--border-focus: rgba(99, 102, 241, .5);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .3);--shadow-md: 0 4px 16px rgba(0, 0, 0, .4);--shadow-lg: 0 8px 32px rgba(0, 0, 0, .5);--shadow-glow: 0 0 20px rgba(99, 102, 241, .15);--shadow-glow-strong: 0 0 30px rgba(99, 102, 241, .25);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;--radius-xl: 24px;--radius-full: 9999px;--transition-fast: .15s cubic-bezier(.4, 0, .2, 1);--transition-base: .3s cubic-bezier(.4, 0, .2, 1);--transition-slow: .5s cubic-bezier(.4, 0, .2, 1);--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, sans-serif}*{box-sizing:border-box;margin:0;padding:0}html{scroll-behavior:smooth;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);line-height:1.6;color:var(--text-primary);background-color:var(--bg-primary);min-height:100vh;overflow-x:hidden}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--bg-elevated);border-radius:var(--radius-full);border:2px solid var(--bg-secondary)}::-webkit-scrollbar-thumb:hover{background:var(--accent-primary)}::selection{background:var(--accent-primary);color:#fff}.app{display:flex;flex-direction:column;min-height:100vh;background-color:transparent}.main-content{flex:1;padding:5rem 2rem 2rem;max-width:1200px;margin:0 auto;width:100%}.container{width:100%;padding:0 1rem;margin:0 auto}.glass-card{background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-default);border-radius:var(--radius-lg);transition:all var(--transition-base)}.glass-card:hover{background:var(--bg-glass-hover);border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.gradient-text{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.glow-border{position:relative}.glow-border:before{content:"";position:absolute;top:-1px;right:-1px;bottom:-1px;left:-1px;border-radius:inherit;background:var(--accent-gradient);z-index:-1;opacity:0;transition:opacity var(--transition-base)}.glow-border:hover:before{opacity:1}.fade-in{animation:fadeIn .5s var(--transition-base) forwards}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.slide-up{animation:slideUp .5s cubic-bezier(.4,0,.2,1) forwards}@keyframes slideUp{0%{opacity:0;transform:translateY(30px)}to{opacity:1;transform:translateY(0)}}@keyframes pulse-glow{0%,to{box-shadow:0 0 5px var(--accent-glow)}50%{box-shadow:0 0 20px var(--accent-glow),0 0 40px #6366f11a}}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}@keyframes float{0%,to{transform:translateY(0)}50%{transform:translateY(-6px)}}@keyframes gradient-shift{0%{background-position:0% 50%}50%{background-position:100% 50%}to{background-position:0% 50%}}.stagger-in>*{opacity:0;animation:fadeIn .5s cubic-bezier(.4,0,.2,1) forwards}.stagger-in>*:nth-child(1){animation-delay:.05s}.stagger-in>*:nth-child(2){animation-delay:.1s}.stagger-in>*:nth-child(3){animation-delay:.15s}.stagger-in>*:nth-child(4){animation-delay:.2s}.stagger-in>*:nth-child(5){animation-delay:.25s}.stagger-in>*:nth-child(6){animation-delay:.3s}.stagger-in>*:nth-child(7){animation-delay:.35s}.stagger-in>*:nth-child(8){animation-delay:.4s}.stagger-in>*:nth-child(9){animation-delay:.45s}.stagger-in>*:nth-child(10){animation-delay:.5s}.alert{padding:.875rem 1.25rem;border-radius:var(--radius-md);font-size:.9rem;font-weight:500;margin-bottom:1.25rem;border:1px solid}.alert-danger{background:var(--danger-soft);color:var(--danger);border-color:#ef444440}.alert-success{background:var(--success-soft);color:var(--success);border-color:#10b98140}@media (max-width: 768px){.main-content{padding:4.5rem 1rem 1rem}.container{padding:0 .75rem}}@media (min-width: 768px){.container{max-width:720px}}@media (min-width: 992px){.container{max-width:960px}}@media (min-width: 1200px){.container{max-width:1140px}}.background-container{position:fixed;top:0;left:0;width:100vw;height:100vh;z-index:-2;pointer-events:none;overflow:hidden}.background-canvas{position:absolute;top:0;left:0;width:100%;height:100%}.background-grid-overlay{position:absolute;top:0;left:0;width:100%;height:100%;background-image:linear-gradient(rgba(99,102,241,.015) 1px,transparent 1px),linear-gradient(90deg,rgba(99,102,241,.015) 1px,transparent 1px);background-size:50px 50px;background-position:center center;pointer-events:none}.header{position:fixed;top:0;left:0;right:0;z-index:100;background:#0a0a0fbf;backdrop-filter:blur(20px) saturate(180%);-webkit-backdrop-filter:blur(20px) saturate(180%);border-bottom:1px solid var(--border-subtle);padding:0 1.5rem;transition:background var(--transition-base)}.header-inner{max-width:1200px;margin:0 auto;display:flex;justify-content:space-between;align-items:center;height:64px}.logo{display:flex;align-items:center;gap:.5rem;text-decoration:none;font-size:1.35rem;font-weight:700;letter-spacing:-.02em;transition:opacity var(--transition-fast)}.logo:hover{opacity:.85}.logo-ring-container{width:28px;height:28px;display:flex;align-items:center;justify-content:center}.logo-ring{width:22px;height:22px;border-radius:50%;border:1.5px solid rgba(99,102,241,.5);box-shadow:0 0 10px #6366f140;position:relative;display:flex;align-items:center;justify-content:center;animation:logo-rotate 4s linear infinite}.logo-orbit-dot{width:5px;height:5px;background:#2dd4bf;border-radius:50%;position:absolute;top:-3px;box-shadow:0 0 8px #2dd4bf}@keyframes logo-rotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.logo-text{color:var(--text-primary)}.logo-accent{background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.nav{display:flex;gap:.25rem;align-items:center}.nav-link{color:var(--text-muted);text-decoration:none;font-weight:500;font-size:.9rem;padding:.5rem 1rem;border-radius:var(--radius-md);transition:all var(--transition-fast);position:relative}.nav-link:hover{color:var(--text-primary);background:#6366f114}.nav-link-active{color:var(--accent-light);background:#6366f11a}.nav-link-active:after{content:"";position:absolute;bottom:0;left:50%;transform:translate(-50%);width:20px;height:2px;background:var(--accent-primary);border-radius:var(--radius-full)}.nav-divider{width:1px;height:24px;background:var(--border-default);margin:0 .5rem}.user-badge{display:flex;align-items:center;gap:.5rem;padding:.3rem .75rem;border-radius:var(--radius-full);background:#6366f114;border:1px solid var(--border-subtle)}.user-avatar{width:28px;height:28px;border-radius:50%;background:var(--accent-gradient);display:flex;align-items:center;justify-content:center;font-weight:700;font-size:.8rem;color:#fff;flex-shrink:0}.user-name{color:var(--text-secondary);font-weight:500;font-size:.85rem;white-space:nowrap}.logout-btn{background:#ef44441a;color:var(--danger);border:1px solid rgba(239,68,68,.2);border-radius:var(--radius-md);padding:.45rem 1rem;font-weight:500;font-size:.85rem;cursor:pointer;transition:all var(--transition-fast);display:flex;align-items:center;gap:.4rem;font-family:var(--font-family)}.logout-btn:hover{background:#ef444433;border-color:#ef444466;transform:translateY(-1px)}.logout-btn:active{transform:translateY(0)}.nav-cta{display:inline-flex;align-items:center;padding:.5rem 1.25rem;background:var(--accent-gradient);color:#fff;text-decoration:none;border-radius:var(--radius-full);font-weight:600;font-size:.85rem;transition:all var(--transition-fast);box-shadow:0 0 15px var(--accent-glow)}.nav-cta:hover{transform:translateY(-1px);box-shadow:0 0 25px var(--accent-glow);filter:brightness(1.1)}.hamburger{display:none;flex-direction:column;gap:5px;padding:8px;background:none;border:none;cursor:pointer;z-index:101}.hamburger span{display:block;width:22px;height:2px;background:var(--text-primary);border-radius:2px;transition:all var(--transition-fast)}.hamburger.active span:nth-child(1){transform:translateY(7px) rotate(45deg)}.hamburger.active span:nth-child(2){opacity:0}.hamburger.active span:nth-child(3){transform:translateY(-7px) rotate(-45deg)}@media (max-width: 768px){.hamburger{display:flex}.nav{position:fixed;top:0;right:-100%;width:280px;height:100vh;background:var(--bg-secondary);border-left:1px solid var(--border-default);flex-direction:column;padding:5rem 1.5rem 2rem;gap:.5rem;align-items:stretch;transition:right var(--transition-base);z-index:100}.nav-open{right:0}.nav-link{padding:.75rem 1rem;font-size:1rem}.nav-divider{width:100%;height:1px;margin:.5rem 0}.user-badge{justify-content:center}.nav-cta{text-align:center;justify-content:center;padding:.75rem}.logout-btn{justify-content:center;padding:.75rem}}.home-container{max-width:1200px;margin:0 auto;padding:1rem 0}.hero-section-no-card{min-height:calc(100vh - 7rem);display:flex;align-items:center;margin-bottom:3rem;position:relative;overflow:hidden}.hero-section-no-card:before{content:"";position:absolute;top:-50%;left:-50%;width:200%;height:200%;background:radial-gradient(circle at 30% 20%,rgba(99,102,241,.04) 0%,transparent 50%),radial-gradient(circle at 70% 80%,rgba(167,139,250,.03) 0%,transparent 50%);pointer-events:none}.hero-grid{display:grid;grid-template-columns:1.2fr .8fr;gap:3rem;align-items:center}.hero-left-column{display:flex;flex-direction:column;align-items:flex-start;text-align:left}.hero-right-column{display:flex;justify-content:center;align-items:center;width:100%;height:400px;position:relative}.hero-chip{display:inline-flex;align-items:center;gap:.5rem;padding:.4rem 1rem;border-radius:var(--radius-full);background:#6366f114;border:1px solid rgba(99,102,241,.25);font-size:.8rem;font-weight:600;color:var(--accent-light);margin-bottom:1.5rem;text-transform:uppercase;letter-spacing:.05em;box-shadow:0 0 10px #6366f10d}.hero-chip-icon{font-size:.7rem;color:var(--accent-primary);display:inline-block}.hero-left-column h1{font-size:3.5rem;font-weight:900;letter-spacing:-.03em;line-height:1.15;margin-bottom:1.5rem;background:linear-gradient(135deg,#fff,#a5b4fc 60%,#c084fc);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text;position:relative;text-align:left}.hero-description-container{position:relative;padding-left:1.25rem;border-left:3px solid var(--accent-primary);margin-bottom:2.25rem;max-width:600px}.hero-description-container p{font-size:1.05rem;line-height:1.6;color:var(--text-secondary);margin:0;text-align:left;max-width:100%}.hero-left-column .search-section{width:100%;max-width:550px;margin:0 0 1.5rem}.hero-left-column .compare-controls{justify-content:flex-start;margin-top:0}.particle-sphere-container{width:100%;height:100%;display:flex;justify-content:center;align-items:center}.particle-sphere-canvas{width:100%;height:100%;max-width:420px;max-height:420px}.compare-controls{display:flex;justify-content:center;gap:1rem;margin-top:1.5rem}.compare-action{padding:.75rem 1.75rem;font-size:.95rem;font-weight:600;font-family:var(--font-family);background:var(--accent-gradient);color:#fff;border:none;border-radius:var(--radius-full);cursor:pointer;transition:all var(--transition-fast);box-shadow:0 0 15px var(--accent-glow)}.compare-action:hover:not(:disabled){transform:translateY(-2px);box-shadow:0 0 25px var(--accent-glow);filter:brightness(1.1)}.compare-action:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;filter:none}.search-section{max-width:600px;margin:0 auto;position:relative}.search-form{display:flex;align-items:flex-start;gap:.5rem}.search-input-container{position:relative;flex-grow:1}.search-input{width:100%;padding:.875rem 1.25rem;font-size:.95rem;font-family:var(--font-family);background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-lg);color:var(--text-primary);transition:all var(--transition-fast);outline:none}.search-input::placeholder{color:var(--text-subtle)}.search-input:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow),var(--shadow-glow)}.search-button{padding:.875rem 1.75rem;font-size:.95rem;font-weight:600;font-family:var(--font-family);background:var(--accent-gradient);color:#fff;border:none;border-radius:var(--radius-lg);cursor:pointer;transition:all var(--transition-fast);white-space:nowrap;box-shadow:0 0 12px var(--accent-glow)}.search-button:hover{transform:translateY(-1px);box-shadow:0 0 20px var(--accent-glow);filter:brightness(1.1)}.search-suggestions{position:absolute;top:calc(100% + 4px);left:0;width:100%;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);box-shadow:var(--shadow-lg);z-index:10;max-height:320px;overflow-y:auto;animation:fadeIn .2s ease forwards}.suggestion-item{padding:.875rem 1.25rem;cursor:pointer;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast)}.suggestion-name{font-weight:500;color:var(--text-primary);margin-bottom:3px;font-size:.9rem}.suggestion-fund-house{font-size:.8rem;color:var(--accent-light);margin-bottom:2px;font-style:italic}.search-spinner{position:absolute;right:12px;top:50%;transform:translateY(-50%);width:20px;height:20px;border:2px solid var(--border-default);border-top:2px solid var(--accent-primary);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{0%{transform:translateY(-50%) rotate(0)}to{transform:translateY(-50%) rotate(360deg)}}.top-portfolios-section,.search-results-section{margin-top:3rem}.section-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.section-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.refresh-button{padding:.55rem 1.25rem;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-md);cursor:pointer;transition:all var(--transition-fast);font-size:.85rem;font-weight:500;font-family:var(--font-family)}.refresh-button:hover:not(:disabled){background:var(--bg-elevated);border-color:var(--accent-primary);color:var(--accent-light)}.refresh-button:disabled{opacity:.4;cursor:not-allowed}.portfolios-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:1.25rem;margin-top:1rem}.portfolio-card{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-base);cursor:pointer;position:relative;overflow:hidden}.portfolio-card.selected{border-color:var(--accent-primary);background:#6366f114;box-shadow:0 0 20px var(--accent-glow)}.portfolio-card.selected:before{opacity:1}.portfolio-card.selected:after{content:"✓";position:absolute;top:14px;right:14px;width:26px;height:26px;background:var(--accent-primary);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:.75rem;font-weight:700}.portfolio-card h3{font-size:1rem;font-weight:600;color:var(--text-primary);margin-bottom:.75rem;line-height:1.4;padding-right:2rem}.portfolio-card p{color:var(--text-muted);margin:.4rem 0;font-size:.85rem}.analyze-button{display:inline-flex;align-items:center;padding:.5rem 1.25rem;background:var(--accent-gradient);color:#fff;text-decoration:none;border-radius:var(--radius-full);margin-top:1rem;font-weight:600;font-size:.8rem;transition:all var(--transition-fast);box-shadow:0 0 10px var(--accent-glow)}.analyze-button:hover{transform:translateY(-1px);box-shadow:0 0 20px var(--accent-glow);filter:brightness(1.1);color:#fff;text-decoration:none}@media (max-width: 768px){.hero-section-no-card{min-height:calc(100vh - 6rem);display:flex;align-items:center;padding:2.5rem 0}.hero-grid{grid-template-columns:1fr;gap:1.5rem}.hero-left-column{align-items:center;text-align:center}.hero-left-column h1{font-size:2.2rem;text-align:center}.hero-description-container{padding-left:0;border-left:none;border-top:2px solid var(--accent-primary);padding-top:1rem;margin-bottom:1.75rem}.hero-description-container p{text-align:center}.hero-left-column .compare-controls{justify-content:center}.hero-right-column{height:300px;order:-1}.search-form{flex-direction:column}.search-button{width:100%}.portfolios-grid{grid-template-columns:1fr}.section-header{flex-direction:column;gap:.75rem;align-items:flex-start}}.dashboard-container{padding:1rem 0;max-width:1200px;margin:0 auto}.dashboard-title{font-size:2.5rem;font-weight:800;letter-spacing:-.03em;margin-bottom:.5rem;text-align:center;background:linear-gradient(135deg,#fff,#818cf8 60%,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.dashboard-subtitle{font-size:1.1rem;color:var(--text-muted);margin-bottom:2.5rem;text-align:center}.dashboard{padding:2rem 0}.dashboard-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:2rem}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.5rem}.portfolio-card{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;cursor:pointer;transition:all var(--transition-base);position:relative;overflow:hidden}.portfolio-card:hover{transform:translateY(-4px);border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.portfolio-card h3{margin-bottom:1rem;color:var(--text-primary);font-weight:600}.chart-container{height:200px;position:relative}.chart-placeholder{width:100%;height:100%;background:var(--bg-tertiary);border-radius:var(--radius-md)}.add-portfolio-form{background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:2rem;margin-bottom:2rem;max-width:600px;margin-left:auto;margin-right:auto;position:relative;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-20px)}to{opacity:1;transform:translateY(0)}}.add-portfolio-form h2{color:var(--text-primary);margin-bottom:1.5rem;font-size:1.5rem;font-weight:700;border-bottom:1px solid var(--border-subtle);padding-bottom:.75rem}.form-group{margin-bottom:1.25rem}.form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--text-secondary)}.form-group input,.form-group textarea{width:100%;padding:.75rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:var(--font-family);transition:all var(--transition-fast);outline:none}.form-group textarea{min-height:100px;resize:vertical}.form-buttons{display:flex;gap:1rem;justify-content:flex-end;margin-top:2rem}.btn{padding:.75rem 1.5rem;border-radius:var(--radius-md);font-size:.95rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none}.btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 0 12px var(--accent-glow)}.btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--accent-glow);filter:brightness(1.1)}.btn-success{background:linear-gradient(135deg,#10b981,#059669);color:#fff}.btn-success:hover{transform:translateY(-2px);box-shadow:0 0 15px #10b9814d}.btn-secondary{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-default)}.btn-secondary:hover{background:var(--bg-elevated);border-color:var(--border-hover)}.btn:active{transform:translateY(0);box-shadow:none}.spinner-container{display:flex;justify-content:center;align-items:center;height:200px}.spinner{width:44px;height:44px;border:3px solid var(--border-default, rgba(99, 102, 241, .15));border-radius:50%;border-top:3px solid var(--accent-primary, #6366f1);animation:spinnerRotate .8s linear infinite;box-shadow:0 0 15px #6366f133}@keyframes spinnerRotate{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.portfolio-manager{padding:0;max-width:1200px;margin:0 auto}.portfolio-manager-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem}.portfolio-manager-header h2{font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.create-portfolio-btn{background:var(--accent-gradient);color:#fff;border:none;padding:.65rem 1.5rem;border-radius:var(--radius-full);cursor:pointer;font-weight:600;font-size:.9rem;font-family:var(--font-family);transition:all var(--transition-fast);box-shadow:0 0 12px var(--accent-glow)}.create-portfolio-btn:hover{transform:translateY(-2px);box-shadow:0 0 20px var(--accent-glow);filter:brightness(1.1)}.portfolio-form-container{background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.75rem;margin-bottom:2rem;position:relative;overflow:hidden;animation:slideDown .3s ease-out}@keyframes slideDown{0%{opacity:0;transform:translateY(-15px)}to{opacity:1;transform:translateY(0)}}.portfolio-form-container:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-gradient)}.portfolio-form-container h3{color:var(--text-primary);font-weight:700;margin-bottom:1.25rem}.portfolio-form{display:flex;flex-direction:column;gap:.75rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-weight:500;font-size:.85rem;color:var(--text-secondary)}.form-group input,.form-group textarea{padding:.7rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.9rem;font-family:var(--font-family);transition:all var(--transition-fast);outline:none}.form-group input::placeholder,.form-group textarea::placeholder{color:var(--text-subtle)}.form-group input:focus,.form-group textarea:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.form-group input[readonly]{opacity:.6;cursor:not-allowed}.form-row{display:flex;gap:1rem}.form-row .form-group{flex:1}.holdings-section{margin-top:1.25rem}.holdings-section h4{color:var(--text-primary);font-weight:600;margin-bottom:.75rem}.add-holding-form{background:var(--bg-tertiary);border:1px solid var(--border-subtle);padding:1.25rem;border-radius:var(--radius-md);margin-bottom:1.25rem}.nav-info{background:#6366f10f;border:1px solid var(--border-default);border-left:3px solid var(--accent-primary);border-radius:var(--radius-md);padding:.75rem 1rem;margin-bottom:1rem}.nav-data{display:flex;justify-content:space-between;margin-bottom:.35rem}.nav-data:last-child{margin-bottom:0}.nav-label{font-weight:500;color:var(--text-muted);font-size:.85rem}.nav-value{font-weight:600;color:var(--accent-light);font-size:.85rem}.form-text{display:block;margin-top:.3rem;font-size:.75rem;color:var(--text-subtle)}.add-holding-btn{background:var(--accent-gradient);color:#fff;border:none;padding:.6rem 1.25rem;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-size:.85rem;font-family:var(--font-family);margin-top:.75rem;transition:all var(--transition-fast);box-shadow:0 0 10px var(--accent-glow)}.add-holding-btn:hover{transform:translateY(-1px);filter:brightness(1.1)}.add-holding-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none;filter:none}.fund-search-container{position:relative}.search-spinner{position:absolute;right:12px;top:38px;width:18px;height:18px;border:2px solid var(--border-default);border-radius:50%;border-top-color:var(--accent-primary);animation:spin .8s ease-in-out infinite}@keyframes spin{to{transform:rotate(360deg)}}.search-suggestions{position:absolute;top:100%;left:0;right:0;background:var(--bg-secondary);border:1px solid var(--border-default);border-radius:0 0 var(--radius-md) var(--radius-md);max-height:280px;overflow-y:auto;z-index:10;box-shadow:var(--shadow-lg)}.suggestion-item{padding:.7rem 1rem;cursor:pointer;border-bottom:1px solid var(--border-subtle);transition:background var(--transition-fast)}.suggestion-item:last-child{border-bottom:none}.suggestion-item:hover{background:#6366f114}.suggestion-name{font-weight:500;font-size:.85rem;color:var(--text-primary)}.suggestion-code{font-size:.75rem;color:var(--text-subtle)}.holdings-table{width:100%;border-collapse:collapse;margin-top:.75rem}.holdings-table th,.holdings-table td{padding:.65rem .875rem;text-align:left;border-bottom:1px solid var(--border-subtle);font-size:.85rem}.holdings-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.03em}.holdings-table tbody tr{transition:background var(--transition-fast)}.remove-btn{background:#ef44441f;color:var(--danger);border:1px solid rgba(239,68,68,.2);padding:.35rem .75rem;border-radius:var(--radius-md);cursor:pointer;font-size:.75rem;font-weight:600;font-family:var(--font-family);transition:all var(--transition-fast)}.remove-btn:hover{background:#ef444433;border-color:#ef444466}.no-holdings-message{text-align:center;color:var(--text-muted);padding:1.5rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px dashed var(--border-default);font-size:.9rem}.form-actions{display:flex;justify-content:flex-end;gap:.75rem;margin-top:1.5rem}.cancel-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-default);padding:.6rem 1.25rem;border-radius:var(--radius-md);cursor:pointer;font-weight:500;font-family:var(--font-family);transition:all var(--transition-fast)}.cancel-btn:hover{background:var(--bg-elevated);border-color:var(--border-hover)}.create-btn{background:var(--accent-gradient);color:#fff;border:none;padding:.6rem 1.25rem;border-radius:var(--radius-md);cursor:pointer;font-weight:600;font-family:var(--font-family);transition:all var(--transition-fast);box-shadow:0 0 10px var(--accent-glow)}.create-btn:hover{filter:brightness(1.1);transform:translateY(-1px)}.create-btn:disabled{opacity:.4;cursor:not-allowed;box-shadow:none;transform:none;filter:none}.portfolios-list-section{margin-top:2rem}.portfolios-list-section h3{color:var(--text-primary);font-weight:700;font-size:1.25rem;margin-bottom:1rem}.portfolios-list{display:grid;grid-template-columns:repeat(auto-fill,minmax(350px,1fr));gap:1.25rem}.portfolio-card{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);border-radius:var(--radius-lg);overflow:hidden;transition:all var(--transition-base)}.portfolio-card:hover{transform:translateY(-3px);border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.portfolio-card-header{padding:1rem 1.25rem;background:var(--bg-tertiary);border-bottom:1px solid var(--border-subtle);display:flex;justify-content:space-between;align-items:center}.portfolio-card-header h3{margin:0;font-size:1rem;font-weight:600;color:var(--text-primary)}.portfolio-actions{display:flex;gap:.5rem}.view-btn{background:#6366f11f;color:var(--accent-light);border:1px solid rgba(99,102,241,.2);padding:.35rem .75rem;border-radius:var(--radius-md);cursor:pointer;font-size:.75rem;font-weight:600;font-family:var(--font-family);transition:all var(--transition-fast)}.view-btn:hover{background:#6366f133;border-color:#6366f166}.delete-btn{background:#ef44441f;color:var(--danger);border:1px solid rgba(239,68,68,.2);padding:.35rem .75rem;border-radius:var(--radius-md);cursor:pointer;font-size:.75rem;font-weight:600;font-family:var(--font-family);transition:all var(--transition-fast)}.delete-btn:hover{background:#ef444433;border-color:#ef444466}.portfolio-card-body{padding:1.25rem}.portfolio-description{color:var(--text-muted);margin-bottom:1rem;font-size:.85rem;line-height:1.5}.portfolio-metrics{display:flex;justify-content:space-between;align-items:center;gap:.75rem}.metric{display:flex;flex-direction:column;align-items:flex-start}.metric-label{font-size:.7rem;color:var(--text-subtle);text-transform:uppercase;letter-spacing:.05em;font-weight:600}.metric-value{font-weight:700;font-size:1rem;color:var(--text-primary)}.positive{color:var(--success)!important}.negative{color:var(--danger)!important}.no-portfolios{text-align:center;padding:3rem;background:var(--bg-secondary);border:1px dashed var(--border-default);border-radius:var(--radius-lg)}.no-portfolios p{color:var(--text-muted);margin-bottom:1rem}.loading{text-align:center;padding:2rem;color:var(--text-muted)}.portfolio-details{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);border-radius:var(--radius-lg);margin-top:2rem;padding:1.5rem}.portfolio-details-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle)}.portfolio-details-header h3{margin:0;color:var(--text-primary);font-weight:700}.close-btn{background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-default);padding:.5rem 1rem;border-radius:var(--radius-md);cursor:pointer;font-family:var(--font-family);font-weight:500;transition:all var(--transition-fast)}.close-btn:hover{background:var(--bg-elevated);border-color:var(--border-hover)}.portfolio-summary{margin-bottom:2rem}.portfolio-metrics-card{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1.25rem}.portfolio-metrics-card h4{color:var(--text-primary);font-weight:600;margin-bottom:1rem}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:.75rem}.metric-item{display:flex;flex-direction:column;gap:.3rem;padding:.75rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.metric-item:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.portfolio-charts{display:grid;grid-template-columns:repeat(3,1fr);gap:1.25rem;margin-bottom:2rem}.chart-card{background:var(--bg-tertiary);border:1px solid var(--border-subtle);border-radius:var(--radius-md);padding:1rem;display:flex;flex-direction:column}.chart-card h4{margin-top:0;margin-bottom:.75rem;text-align:center;color:var(--text-secondary);font-weight:600;font-size:.9rem}.chart-container{height:250px;position:relative}.holdings-details{margin-top:1rem}.holdings-details h4{color:var(--text-primary);font-weight:600;margin-bottom:.75rem}@media (max-width: 1200px){.portfolio-charts{grid-template-columns:repeat(2,1fr)}}@media (max-width: 900px){.form-row{flex-direction:column;gap:.75rem}.metrics-grid{grid-template-columns:repeat(2,1fr)}.portfolio-charts{grid-template-columns:1fr}}@media (max-width: 600px){.portfolios-list,.metrics-grid{grid-template-columns:1fr}.portfolio-card-header{flex-direction:column;align-items:flex-start;gap:.75rem}.portfolio-actions{width:100%;justify-content:flex-end}.portfolio-manager-header{flex-direction:column;gap:.75rem;align-items:stretch}.create-portfolio-btn{text-align:center}}.portfolio{padding:1rem 0;max-width:1200px;margin:0 auto}.portfolio-header{margin-bottom:2.5rem;text-align:center}.portfolio-header h1{font-size:2rem;font-weight:700;letter-spacing:-.02em;color:var(--text-primary);margin-bottom:.75rem}.fund-meta{display:flex;justify-content:center;gap:2rem;color:var(--text-muted);font-size:.9rem}.portfolio-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(300px,1fr));gap:1.5rem;margin-bottom:2rem}.portfolio-card{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-base);position:relative;overflow:hidden}.portfolio-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-gradient);opacity:0;transition:opacity var(--transition-fast)}.portfolio-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.portfolio-card:hover:before{opacity:1}.portfolio-card h2{color:var(--text-primary);font-size:1.2rem;font-weight:600;margin-bottom:1.25rem;padding-bottom:.75rem;border-bottom:1px solid var(--border-subtle)}.fund-details{display:grid;gap:.75rem}.fund-details-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(250px,1fr));gap:.75rem}.detail-item{display:flex;justify-content:space-between;align-items:center;padding:.65rem .875rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:border-color var(--transition-fast)}.detail-item:hover{border-color:var(--border-hover)}.detail-item .label{color:var(--text-muted);font-weight:500;font-size:.85rem}.detail-item .value{color:var(--text-primary);font-weight:600;font-size:.9rem}.chart-container{height:300px;margin-top:1rem;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.duration-selector{display:flex;gap:.4rem;margin-bottom:1rem;justify-content:center}.duration-btn{padding:.45rem 1rem;border:1px solid var(--border-default);border-radius:var(--radius-full);background:var(--bg-tertiary);color:var(--text-muted);cursor:pointer;transition:all var(--transition-fast);font-size:.8rem;font-weight:600;font-family:var(--font-family)}.text-success{color:var(--success)!important}.text-danger{color:var(--danger)!important}.error-message{background:var(--danger-soft);color:var(--danger);border:1px solid rgba(239,68,68,.25);padding:1rem 1.5rem;border-radius:var(--radius-md);margin:2rem auto;max-width:600px;text-align:center}.analysis-section{margin-bottom:2.5rem}.analysis-section>h2{text-align:center;margin-bottom:1.5rem;font-size:1.5rem;font-weight:700;color:var(--text-primary);letter-spacing:-.02em}.metrics-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(150px,1fr));gap:.75rem}.metric-item{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1rem;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);transition:all var(--transition-fast)}.metric-item:hover{transform:translateY(-3px);border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.metric-label{font-size:.8rem;color:var(--text-muted);margin-bottom:.4rem;font-weight:500;text-transform:uppercase;letter-spacing:.05em}.metric-value{font-size:1.25rem;font-weight:700;color:var(--text-primary)}.holdings-table-container{overflow-x:auto;margin-top:1rem;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.holdings-table{width:100%;border-collapse:collapse;font-size:.85rem}.holdings-table th,.holdings-table td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border-subtle)}.holdings-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em;position:sticky;top:0}.holdings-table td{color:var(--text-secondary)}.holdings-table tr{transition:background var(--transition-fast)}.holdings-table tbody tr:hover{background:#6366f10a}.holdings-table tbody tr:last-child td{border-bottom:none}.top-holdings{margin-top:1rem}.holding-bar{margin-bottom:1rem}.holding-name{margin-bottom:.35rem;font-weight:500;color:var(--text-secondary);font-size:.85rem}.holding-bar-container{height:28px;background:var(--bg-tertiary);border-radius:var(--radius-md);overflow:hidden;position:relative;border:1px solid var(--border-subtle)}.holding-bar-fill{height:100%;border-radius:var(--radius-md);transition:width .8s cubic-bezier(.4,0,.2,1)}.holding-percentage{position:absolute;right:10px;top:50%;transform:translateY(-50%);color:#fff;font-weight:600;font-size:.8rem;text-shadow:0 1px 3px rgba(0,0,0,.5)}@media (max-width: 768px){.portfolio-header h1{font-size:1.5rem}.fund-meta{flex-direction:column;gap:.25rem}.portfolio-grid{grid-template-columns:1fr}.metrics-grid{grid-template-columns:repeat(2,1fr)}.duration-selector{flex-wrap:wrap}}.compare-container{max-width:1200px;margin:0 auto;padding:1rem 0}.compare-container h1{text-align:center;margin-bottom:2rem;font-size:2rem;font-weight:700;letter-spacing:-.02em;background:linear-gradient(135deg,#fff,#818cf8 60%,#a78bfa);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.duration-selector{display:flex;justify-content:center;gap:.4rem;margin-bottom:2rem}.duration-btn{padding:.45rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-full);color:var(--text-muted);cursor:pointer;font-weight:600;font-size:.8rem;font-family:var(--font-family);transition:all var(--transition-fast)}.duration-btn:hover{background:var(--bg-elevated);color:var(--text-primary);border-color:var(--border-hover)}.duration-btn.active{background:var(--accent-primary);color:#fff;border-color:var(--accent-primary);box-shadow:0 0 12px var(--accent-glow)}.comparison-section{display:flex;flex-direction:column;gap:1.5rem;margin-bottom:2rem}.comparison-card{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;position:relative;overflow:hidden}.comparison-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-gradient)}.comparison-card h2{margin-bottom:1.25rem;color:var(--text-primary);text-align:center;font-size:1.2rem;font-weight:600}.chart-container{height:400px;position:relative;background:var(--bg-tertiary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);padding:1rem}.metrics-table-container{overflow-x:auto;border-radius:var(--radius-md);border:1px solid var(--border-subtle)}.metrics-table{width:100%;border-collapse:collapse;text-align:left}.metrics-table th,.metrics-table td{padding:.75rem 1rem;border-bottom:1px solid var(--border-subtle)}.metrics-table th{background:var(--bg-tertiary);font-weight:600;color:var(--text-secondary);font-size:.8rem;text-transform:uppercase;letter-spacing:.04em}.metrics-table td{color:var(--text-secondary);font-size:.9rem}.metrics-table tbody tr{transition:background var(--transition-fast)}.metrics-table tbody tr:hover{background:#6366f10a}.metrics-table tbody tr:last-child td{border-bottom:none}.metrics-table .positive{color:var(--success);font-weight:600}.metrics-table .negative{color:var(--danger);font-weight:600}.fund-details-section{display:grid;grid-template-columns:repeat(auto-fill,minmax(300px,1fr));gap:1.25rem}.fund-detail-card{background:var(--bg-glass);backdrop-filter:blur(12px);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border-default);border-radius:var(--radius-lg);padding:1.5rem;transition:all var(--transition-base)}.fund-detail-card:hover{border-color:var(--border-hover);box-shadow:var(--shadow-glow)}.fund-detail-card h3{margin-bottom:1rem;color:var(--text-primary);font-weight:600;font-size:1rem;border-bottom:1px solid var(--border-subtle);padding-bottom:.75rem}.fund-info p{margin:.5rem 0;color:var(--text-muted);font-size:.9rem}.fund-info strong{color:var(--text-secondary)}.back-button{display:block;margin:2rem auto;padding:.75rem 2rem;background:var(--bg-tertiary);color:var(--text-secondary);border:1px solid var(--border-default);border-radius:var(--radius-full);cursor:pointer;font-size:.9rem;font-weight:500;font-family:var(--font-family);transition:all var(--transition-fast)}.back-button:hover{background:var(--bg-elevated);border-color:var(--accent-primary);color:var(--accent-light)}.loading{text-align:center;padding:3rem;font-size:1rem;color:var(--text-muted)}.error-message{text-align:center;padding:1.5rem;font-size:1rem;background:var(--danger-soft);color:var(--danger);border:1px solid rgba(239,68,68,.25);border-radius:var(--radius-md)}@media (max-width: 768px){.compare-container h1{font-size:1.5rem}.chart-container{height:300px}.fund-details-section{grid-template-columns:1fr}.duration-selector{flex-wrap:wrap}}.auth-container{display:flex;justify-content:center;align-items:center;min-height:calc(100vh - 200px);padding:2rem;position:relative}.auth-container:before{content:"";position:absolute;top:20%;left:50%;transform:translate(-50%);width:400px;height:400px;background:radial-gradient(circle,rgba(99,102,241,.08) 0%,transparent 70%);pointer-events:none}.auth-card{background:var(--bg-glass);backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border:1px solid var(--border-default);border-radius:var(--radius-xl);padding:2.5rem;width:100%;max-width:420px;position:relative;animation:slideUp .5s cubic-bezier(.4,0,.2,1) forwards}.auth-card:before{content:"";position:absolute;top:0;left:0;right:0;height:3px;background:var(--accent-gradient);border-radius:var(--radius-xl) var(--radius-xl) 0 0}.auth-card h1{text-align:center;margin-bottom:2rem;font-size:1.75rem;font-weight:700;letter-spacing:-.02em;background:var(--accent-gradient);-webkit-background-clip:text;-webkit-text-fill-color:transparent;background-clip:text}.auth-form{display:flex;flex-direction:column}.auth-form .form-group{margin-bottom:1.25rem}.auth-form .form-group label{display:block;margin-bottom:.5rem;font-weight:500;font-size:.875rem;color:var(--text-secondary)}.form-control{width:100%;padding:.8rem 1rem;background:var(--bg-tertiary);border:1px solid var(--border-default);border-radius:var(--radius-md);color:var(--text-primary);font-size:.95rem;font-family:var(--font-family);transition:all var(--transition-fast);outline:none}.form-control::placeholder{color:var(--text-subtle)}.form-control:focus{border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.auth-form .btn{padding:.85rem;border-radius:var(--radius-md);font-size:1rem;font-weight:600;font-family:var(--font-family);cursor:pointer;transition:all var(--transition-fast);border:none;margin-top:.5rem}.auth-form .btn-primary{background:var(--accent-gradient);color:#fff;box-shadow:0 0 15px var(--accent-glow)}.auth-form .btn-primary:hover{transform:translateY(-2px);box-shadow:0 0 25px var(--accent-glow);filter:brightness(1.1)}.auth-form .btn-primary:disabled{opacity:.5;cursor:not-allowed;transform:none;box-shadow:none;filter:none}.auth-form .btn-primary:active{transform:translateY(0)}.auth-links{text-align:center;margin-top:1.5rem;padding-top:1.5rem;border-top:1px solid var(--border-subtle)}.auth-links p{color:var(--text-muted);font-size:.9rem}.auth-links a{color:var(--accent-light);text-decoration:none;font-weight:600;transition:color var(--transition-fast)}.auth-links a:hover{color:var(--accent-primary);text-decoration:underline}.auth-card .alert{padding:.875rem 1rem;border-radius:var(--radius-md);font-size:.875rem;font-weight:500;margin-bottom:1.25rem}.auth-card .alert-danger{background:var(--danger-soft);color:var(--danger);border:1px solid rgba(239,68,68,.25)}@media (max-width: 480px){.auth-card{padding:1.75rem}.auth-card h1{font-size:1.5rem}}.auth-card .form-group{margin-bottom:1.1rem}
