:root{--text:#6b6375;--text-h:#08060d;--bg:#fff;--border:#e5e4e7;--code-bg:#f4f3ec;--accent:#aa3bff;--accent-bg:#aa3bff1a;--accent-border:#aa3bff80;--social-bg:#f4f3ec80;--shadow:#0000001a 0 10px 15px -3px, #0000000d 0 4px 6px -2px;--sans:system-ui, "Segoe UI", Roboto, sans-serif;--heading:system-ui, "Segoe UI", Roboto, sans-serif;--mono:ui-monospace, Consolas, monospace;font:18px/145% var(--sans);letter-spacing:.18px;--lightningcss-light:initial;--lightningcss-dark: ;color-scheme:light dark;color:var(--text);background:var(--bg);font-synthesis:none;text-rendering:optimizelegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}@media (prefers-color-scheme:dark){:root{--lightningcss-light: ;--lightningcss-dark:initial}}@media (width<=1024px){:root{font-size:16px}}@media (prefers-color-scheme:dark){:root{--text:#9ca3af;--text-h:#f3f4f6;--bg:#16171d;--border:#2e303a;--code-bg:#1f2028;--accent:#c084fc;--accent-bg:#c084fc26;--accent-border:#c084fc80;--social-bg:#2f303a80;--shadow:#0006 0 10px 15px -3px, #00000040 0 4px 6px -2px}#social .button-icon{filter:invert()brightness(2)}}#root{text-align:center;border-inline:1px solid var(--border);box-sizing:border-box;flex-direction:column;width:1126px;max-width:100%;min-height:100svh;margin:0 auto;display:flex}body{margin:0}h1,h2{font-family:var(--heading);color:var(--text-h);font-weight:500}h1{letter-spacing:-1.68px;margin:32px 0;font-size:56px}@media (width<=1024px){h1{margin:20px 0;font-size:36px}}h2{letter-spacing:-.24px;margin:0 0 8px;font-size:24px;line-height:118%}@media (width<=1024px){h2{font-size:20px}}p{margin:0}code,.counter{font-family:var(--mono);color:var(--text-h);border-radius:4px;display:inline-flex}code{background:var(--code-bg);padding:4px 8px;font-size:15px;line-height:135%}*{box-sizing:border-box;margin:0;padding:0}body{color:#1e293b;background:#f8fafc;font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;line-height:1.6}.app{max-width:1200px;margin:0 auto;padding:2rem 1rem}.app-header{text-align:center;margin-bottom:2rem}.app-header h1{color:#0f172a;font-size:1.8rem}.app-header p{color:#64748b;margin-top:.25rem}.share-btn{color:#fff;cursor:pointer;background:#2563eb;border:none;border-radius:6px;margin-top:.75rem;padding:.5rem 1.25rem;font-size:.85rem;transition:background .2s}.share-btn:hover{background:#1d4ed8}.portfolio-section{background:#fff;border-radius:12px;margin-bottom:1.5rem;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.portfolio-header{flex-wrap:wrap;align-items:center;gap:1rem;margin-bottom:1rem;display:flex}.amount-input label{color:#64748b;margin-bottom:.25rem;font-size:.85rem;display:block}.input-group{align-items:center;gap:.5rem;display:flex}.input-group input{border:1px solid #cbd5e1;border-radius:6px;width:120px;padding:.5rem;font-size:1rem}.total-display{color:#0f172a;font-size:1.3rem;font-weight:700}.input-group .unit{color:#64748b;font-size:.9rem}.mode-toggle{cursor:pointer;background:#e2e8f0;border:none;border-radius:6px;padding:.5rem 1rem;font-size:.85rem;transition:background .2s}.mode-toggle:hover{background:#cbd5e1}.add-etf-search{margin-bottom:1rem;position:relative}.add-etf-search input{border:2px solid #e2e8f0;border-radius:8px;width:100%;padding:.75rem 1rem;font-size:.95rem;transition:border-color .2s}.add-etf-search input:focus{border-color:#2563eb;outline:none}.search-loading{color:#64748b;font-size:.85rem;position:absolute;top:50%;right:1rem;transform:translateY(-50%)}.search-results{z-index:10;background:#fff;border:1px solid #e2e8f0;border-radius:8px;max-height:300px;list-style:none;position:absolute;top:100%;left:0;right:0;overflow-y:auto;box-shadow:0 4px 12px #00000026}.search-results li{cursor:pointer;border-bottom:1px solid #f1f5f9;flex-direction:column;padding:.75rem 1rem;display:flex}.search-results li:hover{background:#f1f5f9}.search-meta{color:#94a3b8;margin-top:.125rem;font-size:.8rem}.positions-list{flex-direction:column;gap:.5rem;display:flex}.position-row{background:#f8fafc;border-radius:8px;transition:box-shadow .2s;overflow:hidden}.position-row--expanded{box-shadow:0 2px 8px #00000014}.position-main{cursor:pointer;flex-wrap:wrap;justify-content:space-between;align-items:center;gap:1rem;padding:.75rem;display:flex}.position-main:hover{background:#f1f5f9}.expand-icon{color:#94a3b8;margin-left:.4rem;font-size:.75rem}.position-info{flex-direction:column;flex:1;min-width:200px;display:flex}.position-name{font-size:.9rem;font-weight:600}.position-detail{border-top:1px solid #e2e8f0;padding:0 1rem 1rem;animation:.2s slideDown}@keyframes slideDown{0%{opacity:0;max-height:0}to{opacity:1;max-height:500px}}.detail-grid{grid-template-columns:1fr 1fr;gap:1.5rem;margin-top:.75rem;display:grid}.detail-section h4{color:#64748b;text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem;font-size:.8rem}.detail-section dl{grid-template-columns:auto 1fr;gap:.2rem .75rem;font-size:.8rem;display:grid}.detail-section dt{color:#94a3b8}.detail-section dd{color:#334155;margin:0;font-weight:500}.returns dd.positive{color:#16a34a}.returns dd.negative{color:#dc2626}.returns dd.neutral{color:#94a3b8}.volatility{color:#94a3b8;margin-top:.5rem;font-size:.75rem}@media (width<=640px){.detail-grid{grid-template-columns:1fr}}.position-isin{color:#64748b;font-family:monospace;font-size:.8rem}.position-ter{color:#94a3b8;font-size:.75rem}.position-loading{color:#2563eb;font-size:.75rem}.position-controls{align-items:center;gap:.75rem;display:flex}.weight-slider{accent-color:#2563eb;width:150px}.weight-display{text-align:right;min-width:55px;font-size:.9rem;font-weight:600}.euro-input{align-items:center;gap:.25rem;display:flex}.euro-input input{text-align:right;border:1px solid #cbd5e1;border-radius:4px;width:80px;padding:.25rem .5rem}.remove-btn{color:#94a3b8;cursor:pointer;background:0 0;border:none;border-radius:4px;padding:.25rem .5rem;font-size:1.1rem;transition:all .2s}.remove-btn:hover{color:#ef4444;background:#fef2f2}.empty-state{text-align:center;color:#94a3b8;padding:2rem}.warning-banner{background:#fef3c7;border:1px solid #f59e0b;border-radius:8px;margin-bottom:1.5rem;padding:1rem 1.25rem}.warning-banner strong{color:#92400e}.warning-banner ul{margin-top:.5rem;padding-left:1.25rem}.warning-banner li{color:#92400e;font-size:.9rem}.charts-grid{flex-direction:column;gap:1.5rem;margin-bottom:1.5rem;display:flex}.chart-card{background:#fff;border-radius:12px;padding:1.5rem;box-shadow:0 1px 3px #0000001a}.chart-card h3{color:#334155;margin-bottom:1rem;font-size:1rem}.chart-subtitle{color:#94a3b8;margin-top:-.75rem;margin-bottom:.75rem;font-size:.8rem}.table-wrapper{overflow-x:auto}.table-wrapper table{border-collapse:collapse;width:100%}.table-wrapper th,.table-wrapper td{text-align:left;border-bottom:1px solid #f1f5f9;padding:.5rem .75rem;font-size:.85rem}.table-wrapper th{color:#64748b;font-weight:600}.full-width-section{margin-bottom:1.5rem}.map-legend{flex-wrap:wrap;gap:.75rem;margin-bottom:.75rem;display:flex}.legend-item{color:#64748b;align-items:center;gap:.25rem;font-size:.75rem;display:flex}.legend-swatch{border:1px solid #e2e8f0;border-radius:2px;width:14px;height:14px;display:inline-block}.sparplan-inputs{flex-wrap:wrap;gap:1rem;margin-bottom:1.25rem;display:flex}.sparplan-field label{color:#64748b;margin-bottom:.25rem;font-size:.8rem;display:block}.sparplan-field input{border:1px solid #cbd5e1;border-radius:6px;width:100px;padding:.4rem .5rem;font-size:.9rem}.sparplan-summary{flex-wrap:wrap;gap:2rem;margin-bottom:1.25rem;display:flex}.summary-item{flex-direction:column;display:flex}.summary-label{color:#94a3b8;text-transform:uppercase;letter-spacing:.05em;font-size:.75rem}.summary-value{color:#334155;font-size:1.1rem;font-weight:700}.summary-value.gains{color:#16a34a}.summary-value.total{color:#2563eb}.preload-overlay{z-index:1000;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);background:#00000080;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.preload-modal{text-align:center;background:#fff;border-radius:16px;width:90%;max-width:440px;padding:2rem 2.5rem;box-shadow:0 20px 60px #0000004d}.preload-modal h2{color:#0f172a;margin-bottom:.5rem;font-size:1.2rem}.preload-modal p{color:#64748b;margin-bottom:1.25rem;font-size:.85rem;line-height:1.5}.preload-progress-bar{background:#e2e8f0;border-radius:4px;height:8px;margin-bottom:.5rem;overflow:hidden}.preload-progress-fill{background:#2563eb;border-radius:4px;height:100%;transition:width .4s}.preload-count{color:#94a3b8;margin-bottom:.75rem;font-size:.8rem}.preload-done{color:#16a34a;font-size:1rem;font-weight:600}.preload-errors{text-align:left;color:#94a3b8;margin-top:.75rem;font-size:.8rem}.preload-errors summary{cursor:pointer;color:#f59e0b}.preload-errors ul{margin-top:.25rem;padding-left:1rem}.preload-skip{cursor:pointer;color:#64748b;background:#f1f5f9;border:none;border-radius:6px;margin-top:.75rem;padding:.4rem 1.25rem;font-size:.8rem;transition:background .2s}.preload-skip:hover{background:#e2e8f0}@media (width<=640px){.charts-grid{grid-template-columns:1fr}.position-row{flex-direction:column;align-items:stretch}.position-controls{justify-content:space-between}.weight-slider{flex:1}}
