@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700;800&family=Nunito:wght@400;600;700;800;900&display=swap";[data-theme=professional]{--bg-primary:#0a0f1e;--bg-secondary:#0d1528;--bg-card:#101c38cc;--bg-card-hover:#162648e6;--bg-input:#ffffff0f;--bg-input-focus:#ffffff1a;--bg-btn-primary:linear-gradient(135deg, #1a56db, #0ea5e9);--bg-btn-secondary:#ffffff14;--bg-tag:#0ea5e926;--text-primary:#e2e8f0;--text-secondary:#b8c8d8;--text-muted:#8fa3b8;--text-accent:#38bdf8;--text-success:#34d399;--text-danger:#f87171;--text-warning:#fbbf24;--border-color:#ffffff14;--border-focus:#1a56db;--border-radius-sm:8px;--border-radius-md:12px;--border-radius-lg:16px;--border-radius-xl:24px;--shadow-card:0 4px 24px #0006, 0 0 0 1px #ffffff0d;--shadow-btn:0 4px 15px #1a56db66;--shadow-glow:0 0 30px #0ea5e926;--glass-backdrop:blur(20px);--gradient-hero:linear-gradient(135deg, #0a0f1e 0%, #0d1f44 50%, #0a0f1e 100%);--gradient-accent:linear-gradient(135deg, #1a56db, #0ea5e9);--gradient-success:linear-gradient(135deg, #059669, #34d399);--gradient-card-border:linear-gradient(135deg, #ffffff1a, #ffffff05);--font-display:"Inter", "SF Pro Display", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--chart-color-1:#38bdf8;--chart-color-2:#818cf8;--chart-color-3:#34d399;--chart-color-4:#fbbf24;--chart-color-5:#f87171;--chart-grid:#ffffff0f;--chart-bg:#0a0f1e99}[data-theme=kawaii]{--bg-primary:#fff0f7;--bg-secondary:#ffe4f0;--bg-card:#ffffffd9;--bg-card-hover:#fffffff2;--bg-input:#ffc0db33;--bg-input-focus:#ffc0db59;--bg-btn-primary:linear-gradient(135deg, #f472b6, #ec4899);--bg-btn-secondary:#f472b626;--bg-tag:#f472b633;--text-primary:#4a1942;--text-secondary:#9d4e8c;--text-muted:#c084b8;--text-accent:#ec4899;--text-success:#10b981;--text-danger:#ef4444;--text-warning:#f59e0b;--border-color:#f472b64d;--border-focus:#ec4899;--border-radius-sm:12px;--border-radius-md:18px;--border-radius-lg:24px;--border-radius-xl:32px;--shadow-card:0 8px 32px #ec489926, 0 2px 8px #ec48991a;--shadow-btn:0 4px 20px #ec489973;--shadow-glow:0 0 40px #f472b633;--glass-backdrop:blur(16px) saturate(1.8);--gradient-hero:linear-gradient(135deg, #fff0f7 0%, #fce7f3 50%, #fdf2f8 100%);--gradient-accent:linear-gradient(135deg, #f472b6, #ec4899);--gradient-success:linear-gradient(135deg, #34d399, #10b981);--gradient-card-border:linear-gradient(135deg, #f472b666, #ec48991a);--font-display:"Nunito", "Rounded Mplus 1c", sans-serif;--font-mono:"JetBrains Mono", monospace;--chart-color-1:#f472b6;--chart-color-2:#a78bfa;--chart-color-3:#34d399;--chart-color-4:#fbbf24;--chart-color-5:#f87171;--chart-grid:#f472b626;--chart-bg:#fff0f7b3}[data-theme=minimal]{--bg-primary:#fafafa;--bg-secondary:#f4f4f5;--bg-card:#fff;--bg-card-hover:#f8f8f8;--bg-input:#f4f4f5;--bg-input-focus:#e4e4e7;--bg-btn-primary:linear-gradient(135deg, #18181b, #3f3f46);--bg-btn-secondary:#f4f4f5;--bg-tag:#e4e4e7;--text-primary:#18181b;--text-secondary:#52525b;--text-muted:#a1a1aa;--text-accent:#18181b;--text-success:#16a34a;--text-danger:#dc2626;--text-warning:#d97706;--border-color:#e4e4e7;--border-focus:#18181b;--border-radius-sm:4px;--border-radius-md:6px;--border-radius-lg:8px;--border-radius-xl:12px;--shadow-card:0 1px 3px #00000014, 0 1px 2px #0000000f;--shadow-btn:0 2px 8px #00000026;--shadow-glow:none;--glass-backdrop:none;--gradient-hero:linear-gradient(180deg, #fafafa 0%, #f4f4f5 100%);--gradient-accent:linear-gradient(135deg, #18181b, #3f3f46);--gradient-success:linear-gradient(135deg, #16a34a, #22c55e);--gradient-card-border:none;--font-display:"Inter", "Helvetica Neue", sans-serif;--font-mono:"JetBrains Mono", "Fira Code", monospace;--chart-color-1:#18181b;--chart-color-2:#52525b;--chart-color-3:#16a34a;--chart-color-4:#d97706;--chart-color-5:#dc2626;--chart-grid:#0000000f;--chart-bg:#fff}*,:before,:after{box-sizing:border-box;margin:0;padding:0}:root{--transition:.25s cubic-bezier(.4, 0, .2, 1);--transition-slow:.5s cubic-bezier(.4, 0, .2, 1)}html{font-size:16px}body{font-family:var(--font-display);background:var(--bg-primary);color:var(--text-primary);min-height:100vh;transition:background var(--transition-slow), color var(--transition);overflow-x:hidden}#root{min-height:100vh}.app-root{background:var(--gradient-hero);flex-direction:column;min-height:100vh;display:flex;position:relative}.bg-stars{pointer-events:none;z-index:0;position:fixed;inset:0}.star{background:#fff9;border-radius:50%;animation:3s ease-in-out infinite alternate twinkle;position:absolute}@keyframes twinkle{0%{opacity:.1;transform:scale(1)}to{opacity:.8;transform:scale(1.3)}}.bg-blobs{pointer-events:none;z-index:0;position:fixed;inset:0;overflow:hidden}.blob{filter:blur(80px);opacity:.35;border-radius:50%;animation:8s ease-in-out infinite float;position:absolute}.blob-1{background:#f9a8d4;width:500px;height:500px;animation-delay:0s;top:-150px;left:-150px}.blob-2{background:#c4b5fd;width:400px;height:400px;animation-delay:3s;top:30%;right:-100px}.blob-3{background:#fbcfe8;width:350px;height:350px;animation-delay:5s;bottom:-100px;left:30%}@keyframes float{0%,to{transform:translate(0)scale(1)}33%{transform:translate(30px,-40px)scale(1.05)}66%{transform:translate(-20px,20px)scale(.97)}}.app-header{z-index:100;background:var(--bg-card);-webkit-backdrop-filter:var(--glass-backdrop);backdrop-filter:var(--glass-backdrop);border-bottom:1px solid var(--border-color);transition:background var(--transition-slow);position:sticky;top:0;box-shadow:0 2px 20px #0000001f}.header-inner{justify-content:space-between;align-items:center;gap:16px;max-width:1440px;margin:0 auto;padding:14px 24px;display:flex}.header-brand{align-items:center;gap:14px;display:flex}.brand-icon{font-size:2rem;line-height:1;animation:3s ease-in-out infinite pulse-icon;overflow:hidden}.icon-img{object-fit:contain;mix-blend-mode:multiply;width:50px;height:50px;transform:scale(1.4)}@keyframes pulse-icon{0%,to{transform:scale(1)}50%{transform:scale(1.08)}}.brand-title{letter-spacing:-.5px;background:var(--gradient-accent);-webkit-text-fill-color:transparent;-webkit-background-clip:text;background-clip:text;font-size:1.4rem;font-weight:800}[data-theme=minimal] .brand-title{-webkit-text-fill-color:var(--text-primary);color:var(--text-primary);background:0 0}.brand-sub{color:var(--text-muted);letter-spacing:.3px;font-size:.75rem;font-weight:400}.theme-switcher{align-items:center;gap:10px;display:flex}.theme-label{color:var(--text-muted);white-space:nowrap;font-size:.75rem}.theme-buttons{background:var(--bg-input);border-radius:var(--border-radius-md);border:1px solid var(--border-color);gap:6px;padding:4px;display:flex}.theme-btn{color:var(--text-secondary);border-radius:calc(var(--border-radius-md) - 2px);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:0 0;border:none;padding:6px 12px;font-family:inherit;font-size:.8rem;font-weight:500}.theme-btn:hover{background:var(--bg-btn-secondary);color:var(--text-primary)}.theme-btn.active{background:var(--bg-btn-primary);color:#fff;box-shadow:var(--shadow-btn)}[data-theme=minimal] .theme-btn.active{color:#fff}.app-main{z-index:1;flex:1;width:100%;max-width:1440px;margin:0 auto;padding:28px 24px;position:relative}.main-layout{grid-template-columns:minmax(400px,480px) 1fr;align-items:start;gap:20px;display:grid}.left-col,.right-col{flex-direction:column;gap:16px;display:flex}.card{background:var(--bg-card);-webkit-backdrop-filter:var(--glass-backdrop);backdrop-filter:var(--glass-backdrop);border-radius:var(--border-radius-lg);border:1px solid var(--border-color);box-shadow:var(--shadow-card);transition:box-shadow var(--transition), transform var(--transition), background var(--transition-slow);padding:22px}.card:hover{box-shadow:var(--shadow-card), var(--shadow-glow);transform:translateY(-1px)}[data-theme=minimal] .card:hover{transform:none}.panel-header{flex-wrap:wrap;justify-content:space-between;align-items:center;gap:8px;margin-bottom:18px;display:flex}.panel-title{color:var(--text-primary);font-size:1.05rem;font-weight:700}.chart-subtitle{color:var(--text-muted);font-size:.78rem}.total-badge{background:var(--bg-tag);color:var(--text-accent);border:1px solid var(--border-color);border-radius:999px;padding:4px 10px;font-size:.78rem;font-weight:600}.stocks-collapsible{opacity:1;max-height:4000px;transition:max-height .4s cubic-bezier(.4,0,.2,1),opacity .3s;overflow:hidden}.stocks-collapsible.collapsed{opacity:0;pointer-events:none;max-height:0}.panel-header-right{align-items:center;gap:8px;display:flex}.btn-collapse{background:var(--bg-btn-secondary);width:28px;height:28px;color:var(--text-secondary);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition);border:none;justify-content:center;align-items:center;font-family:inherit;font-size:.7rem;display:flex}.btn-collapse:hover{background:var(--bg-tag);color:var(--text-accent)}.stocks-list{flex-direction:column;gap:10px;display:flex}.stock-row{background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-md);transition:all var(--transition);flex-direction:column;gap:10px;padding:12px 14px;display:flex}.stock-row:hover{border-color:var(--border-focus);background:var(--bg-input-focus)}.stock-row-top{align-items:flex-start;gap:10px;display:flex}.market-select{flex-shrink:0}.symbol-field{flex-direction:column;flex:1;gap:3px;min-width:0;display:flex}.symbol-input{letter-spacing:.3px;width:100%;font-size:.95rem;font-weight:600}.symbol-hint-row{white-space:nowrap;text-overflow:ellipsis;min-height:16px;overflow:hidden}.hint{white-space:nowrap;text-overflow:ellipsis;vertical-align:bottom;max-width:100%;font-size:.72rem;font-weight:500;display:inline-block;overflow:hidden}.hint.loading{color:var(--text-muted)}.hint.error{color:var(--text-danger)}.hint.name{color:var(--text-success)}.stock-row-bottom{border-top:1px solid var(--border-color);grid-template-columns:1fr 1fr 1fr;gap:10px;padding-top:6px;display:grid}.dual-price{flex-direction:column;gap:2px;display:flex}.price-twd{color:var(--text-muted);font-size:.7rem;font-weight:500}.stock-row-cagr{border-top:1px solid var(--border-color);padding-top:6px}.cagr-field{width:100%}.cagr-input-row{flex-wrap:wrap;align-items:center;gap:8px;display:flex}.cagr-wrap{max-width:160px;position:relative}.cagr-input{width:100%;padding:6px 30px 6px 10px;font-size:.85rem}.cagr-auto-tag{color:var(--text-muted);background:var(--bg-input);border:1px solid var(--border-color);border-radius:var(--border-radius-sm);white-space:nowrap;padding:3px 8px;font-size:.72rem}.btn-cagr-reset{border:1px solid var(--border-color);color:var(--text-muted);border-radius:var(--border-radius-sm);cursor:pointer;transition:all var(--transition);white-space:nowrap;background:0 0;padding:3px 8px;font-family:inherit;font-size:.72rem}.btn-cagr-reset:hover{color:var(--text-accent);border-color:var(--text-accent);background:var(--bg-tag)}.stock-row-dca{border-top:1px solid var(--border-color);grid-template-columns:1fr 1fr;gap:10px;padding-top:6px;display:grid}.dca-mode-label{flex-wrap:wrap;align-items:center;gap:2px;display:flex}.dca-mode-btn{color:var(--text-muted);cursor:pointer;transition:all var(--transition);letter-spacing:.3px;text-transform:uppercase;background:0 0;border:none;border-radius:3px;padding:1px 4px;font-family:inherit;font-size:.68rem;font-weight:600}.dca-mode-btn.dca-mode-active{color:var(--text-accent);background:var(--bg-tag)}.dca-mode-btn:hover:not(.dca-mode-active){color:var(--text-secondary)}.dca-input{padding:6px 6px 6px 34px;font-size:.85rem}.stock-field{flex-direction:column;gap:4px;display:flex}.field-label{color:var(--text-muted);text-transform:uppercase;letter-spacing:.5px;font-size:.68rem;font-weight:600}.shares-input{padding:7px 10px;font-size:.9rem}.price-display,.value-display{font-size:.9rem;font-weight:700;font-family:var(--font-mono);color:#fff;padding:7px 0}.price-display.muted,.value-display.muted{color:var(--text-muted)}.value-display.highlight{color:var(--text-accent)}[data-theme=minimal] .value-display.highlight{color:var(--text-primary)}.btn-remove{width:28px;height:28px;color:var(--text-muted);cursor:pointer;border-radius:var(--border-radius-sm);transition:all var(--transition);background:0 0;border:none;justify-content:center;align-items:center;font-family:inherit;font-size:.75rem;display:flex}.btn-remove:hover{color:var(--text-danger);background:#f8717126}.empty-state{text-align:center;color:var(--text-muted);padding:32px 16px}.empty-icon{margin-bottom:12px;font-size:3rem;animation:2s ease-in-out infinite bounce}@keyframes bounce{0%,to{transform:translateY(0)}50%{transform:translateY(-8px)}}.chart-empty{min-height:280px;color:var(--text-muted);flex-direction:column;justify-content:center;align-items:center;gap:12px;display:flex}.chart-empty .empty-icon{font-size:3.5rem}.text-input,.select-input{border:1px solid var(--border-color);border-radius:var(--border-radius-sm);background:var(--bg-input);width:100%;color:var(--text-primary);transition:all var(--transition);appearance:none;outline:none;padding:9px 12px;font-family:inherit;font-size:.88rem}.text-input:focus,.select-input:focus{border-color:var(--border-focus);background:var(--bg-input-focus);box-shadow:0 0 0 3px #1a56db26}[data-theme=kawaii] .text-input:focus,[data-theme=kawaii] .select-input:focus{box-shadow:0 0 0 3px #ec489926}[data-theme=minimal] .text-input:focus,[data-theme=minimal] .select-input:focus{box-shadow:0 0 0 2px #18181b1a}.text-input::placeholder{color:var(--text-muted)}.market-select{width:110px}.select-input{cursor:pointer}.full-width{width:100%}.input-prefix-wrap{align-items:center;display:flex;position:relative}.input-prefix,.input-suffix{color:var(--text-muted);pointer-events:none;font-size:.85rem;font-weight:500;position:absolute}.input-prefix{left:10px}.input-suffix{right:10px}.text-input.with-prefix{padding-left:38px}.plan-grid{grid-template-columns:1fr 1fr;gap:18px;display:grid}.form-group{flex-direction:column;gap:8px;display:flex}.form-label{color:var(--text-secondary);font-size:.8rem;font-weight:600}.range-wrapper{align-items:center;gap:10px;display:flex}.range-input{appearance:none;background:var(--border-color);cursor:pointer;border-radius:999px;outline:none;flex:1;height:4px}.range-input::-webkit-slider-thumb{-webkit-appearance:none;background:var(--gradient-accent);cursor:pointer;width:18px;height:18px;transition:transform var(--transition);box-shadow:var(--shadow-btn);border-radius:50%}.range-input::-webkit-slider-thumb:hover{transform:scale(1.2)}.range-value{color:var(--text-accent);text-align:right;min-width:48px;font-size:.85rem;font-weight:700}[data-theme=minimal] .range-value{color:var(--text-primary)}.toggle-group{flex-direction:column}.toggle-switch{cursor:pointer;align-items:center;gap:10px;display:flex}.toggle-switch input{display:none}.toggle-track{background:var(--bg-input);border:1px solid var(--border-color);width:42px;height:24px;transition:all var(--transition);border-radius:999px;flex-shrink:0;position:relative}.toggle-switch input:checked+.toggle-track{background:var(--gradient-accent);border-color:#0000}.toggle-thumb{width:18px;height:18px;transition:transform var(--transition);background:#fff;border-radius:50%;position:absolute;top:2px;left:2px;box-shadow:0 2px 4px #0003}.toggle-switch input:checked~.toggle-track .toggle-thumb,.toggle-switch input:checked+.toggle-track .toggle-thumb{transform:translate(18px)}.toggle-text{color:var(--text-muted);font-size:.8rem;font-weight:500}.btn-add,.btn-primary{cursor:pointer;border-radius:var(--border-radius-md);transition:all var(--transition);border:none;justify-content:center;align-items:center;gap:8px;font-family:inherit;font-weight:600;display:flex}.btn-add{background:var(--bg-btn-secondary);width:100%;color:var(--text-secondary);border:2px dashed var(--border-color);border-radius:var(--border-radius-md);margin-top:14px;padding:11px;font-size:.9rem}.btn-add:hover{background:var(--bg-tag);color:var(--text-accent);border-color:var(--text-accent);transform:translateY(-1px)}.btn-primary{background:var(--bg-btn-primary);color:#fff;box-shadow:var(--shadow-btn);padding:12px 24px;font-size:.95rem}.btn-primary:hover:not(:disabled){box-shadow:var(--shadow-btn), 0 8px 25px #1a56db4d;filter:brightness(1.08);transform:translateY(-2px)}.btn-primary:disabled{opacity:.6;cursor:not-allowed}.btn-calculate{letter-spacing:.3px;border-radius:var(--border-radius-lg);width:100%;padding:15px;font-size:1.05rem;font-weight:700}.btn-spinner{border:2px solid #ffffff4d;border-top-color:#fff;border-radius:50%;width:16px;height:16px;animation:.7s linear infinite spin;display:inline-block}@keyframes spin{to{transform:rotate(360deg)}}.summary-cards{grid-template-columns:repeat(auto-fill,minmax(180px,1fr));gap:12px;display:grid}.stat-card{background:var(--bg-card);border:1px solid var(--border-color);border-radius:var(--border-radius-md);transition:all var(--transition);box-shadow:var(--shadow-card);align-items:flex-start;gap:12px;padding:16px;display:flex}.stat-card:hover{box-shadow:var(--shadow-card), var(--shadow-glow);transform:translateY(-2px)}.stat-card--accent{background:var(--bg-btn-primary);color:#fff;border-color:#0000}.stat-card--accent .stat-label,.stat-card--accent .stat-value,.stat-card--accent .stat-sub{color:#ffffffe6}.stat-icon{flex-shrink:0;font-size:1.5rem;line-height:1}.stat-body{flex-direction:column;gap:3px;min-width:0;display:flex}.stat-label{color:var(--text-muted);font-size:.72rem;font-weight:500}.stat-value{color:var(--text-primary);font-size:1.05rem;font-weight:800;line-height:1.2}.stat-sub{color:var(--text-muted);white-space:nowrap;text-overflow:ellipsis;font-size:.7rem;overflow:hidden}.chart-container{height:340px;position:relative}.goal-body{flex-direction:column;gap:16px;display:flex}.goal-input-row{align-items:stretch;gap:10px;display:flex}.goal-input-row .input-prefix-wrap{flex:1}.goal-btn{white-space:nowrap;align-self:stretch;padding:0 22px}.goal-results{flex-direction:column;gap:12px;animation:.4s fadeIn;display:flex}@keyframes fadeIn{0%{opacity:0;transform:translateY(8px)}to{opacity:1;transform:translateY(0)}}.goal-result-item{background:var(--bg-input);border-radius:var(--border-radius-md);border:1px solid var(--border-color);transition:background var(--transition);align-items:center;gap:12px;padding:14px;display:flex}.goal-result-icon{flex-shrink:0;font-size:1.4rem}.goal-result-label{color:var(--text-muted);margin-bottom:3px;font-size:.75rem}.goal-result-value{color:var(--text-primary);font-size:1rem;font-weight:700}.goal-hint{color:var(--text-muted);background:var(--bg-input);border-radius:var(--border-radius-sm);padding:10px;font-size:.8rem}.error-banner{border-radius:var(--border-radius-md);color:var(--text-danger);background:#f871711f;border:1px solid #f871714d;padding:12px 16px;font-size:.85rem;font-weight:500}.app-footer{z-index:1;text-align:center;color:var(--text-muted);border-top:1px solid var(--border-color);padding:16px 24px;font-size:.73rem;position:relative}@media (width<=1024px){.main-layout{grid-template-columns:1fr}.plan-grid{grid-template-columns:1fr 1fr}}@media (width<=768px){.app-main{padding:12px 10px}.header-inner{gap:8px;padding:10px 14px}.brand-sub,.theme-label{display:none}.plan-grid,.summary-cards{grid-template-columns:1fr 1fr}.chart-container{height:280px}}@media (width<=640px){.app-main{padding:8px}.header-inner{padding:8px 12px}.brand-title{font-size:1rem}.brand-icon{font-size:1.5rem}.theme-btn{padding:5px 7px;font-size:.7rem}.market-select{width:85px;font-size:.8rem}.stock-row{gap:8px;padding:10px}.stock-row-bottom{grid-template-columns:1fr 1fr;gap:8px}.stock-row-dca{grid-template-columns:1fr;gap:8px}.summary-cards{grid-template-columns:1fr 1fr;gap:8px}.chart-container{height:240px}.plan-grid{grid-template-columns:1fr;gap:12px}.card{padding:14px}.cagr-input-row{flex-direction:column;align-items:flex-start}.cagr-wrap{width:100%;max-width:100%}}@media (width<=400px){.app-main{padding:6px}.brand-title{font-size:.9rem}.theme-buttons{gap:3px}.theme-btn{padding:4px 6px;font-size:.65rem}.stock-row-bottom,.summary-cards{grid-template-columns:1fr}.stat-card{padding:12px}.chart-container{height:200px}.total-badge,.dual-price .price-twd{display:none}}[data-theme=kawaii] .card{border-color:#f472b633}[data-theme=kawaii] .btn-add:hover{border-color:var(--text-accent)}[data-theme=kawaii] .stat-card--accent{background:linear-gradient(135deg,#f472b6,#ec4899)}[data-theme=kawaii] .empty-icon{filter:hue-rotate(300deg)}[data-theme=minimal] .card{border-color:var(--border-color);border-width:1.5px}[data-theme=minimal] .brand-icon,[data-theme=minimal] .panel-title{filter:grayscale()}[data-theme=minimal] .stat-card--accent,[data-theme=minimal] .toggle-switch input:checked+.toggle-track{background:#18181b}[data-theme=minimal] .range-input::-webkit-slider-thumb{background:#18181b}
