:root{--bg-primary: #1a1d24;--bg-secondary: #232830;--bg-card: #282d36;--bg-card-hover: #2f3541;--accent-primary: #DD8950;--accent-secondary: #E9A06A;--accent-muted: #953A27;--accent-glow: rgba(221, 137, 80, .12);--brand-navy: #061C51;--brand-burgundy: #300D17;--brand-purple: #3D3768;--brand-rust: #953A27;--success: #6b9b7a;--success-bg: rgba(107, 155, 122, .1);--error: #c47a7a;--error-bg: rgba(196, 122, 122, .1);--text-primary: #e8e4df;--text-secondary: #9a958e;--text-muted: #6b675f;--border-subtle: rgba(255, 255, 255, .05);--border-accent: rgba(184, 149, 108, .25);--shadow-sm: 0 2px 8px rgba(0, 0, 0, .25);--shadow-md: 0 4px 20px rgba(0, 0, 0, .35);--shadow-lg: 0 8px 40px rgba(0, 0, 0, .45);--shadow-glow: 0 0 40px rgba(184, 149, 108, .08);--radius-sm: 6px;--radius-md: 10px;--radius-lg: 16px;font-family:Outfit,system-ui,-apple-system,sans-serif;line-height:1.6;font-weight:400;color-scheme:dark;color:var(--text-primary);background-color:var(--bg-primary);font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}*{margin:0;padding:0;box-sizing:border-box}body{min-height:100vh;background:linear-gradient(135deg,#1a1d24,#232830 30%,#2d3038,#3d3530 70%,#4a3d32,#5c4a3a);background-attachment:fixed}#root{min-height:100vh;display:flex;flex-direction:column}::-webkit-scrollbar{width:6px;height:6px}::-webkit-scrollbar-track{background:var(--bg-secondary)}::-webkit-scrollbar-thumb{background:var(--text-muted);border-radius:3px}::-webkit-scrollbar-thumb:hover{background:var(--text-secondary)}:focus-visible{outline:2px solid var(--accent-primary);outline-offset:2px}::selection{background:#b8956c40;color:var(--text-primary)}.asset-form{display:flex;flex-direction:column;gap:1rem}.asset-list{display:flex;flex-direction:column;gap:.625rem}.asset-row{display:flex;align-items:center;gap:.625rem;animation:slideIn .25s ease forwards;opacity:0;transform:translateY(-8px)}@keyframes slideIn{to{opacity:1;transform:translateY(0)}}.asset-inputs{flex:1;display:flex;gap:.5rem;align-items:center}.asset-name-input{flex:1;min-width:0;padding:.6875rem .875rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:inherit;transition:all .2s ease}.asset-name-input:hover{border-color:var(--border-accent)}.asset-name-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.asset-name-input::placeholder{color:var(--text-muted)}.amount-input-wrapper{position:relative;width:110px;flex-shrink:0}.currency-symbol{position:absolute;left:.75rem;top:50%;transform:translateY(-50%);color:var(--text-muted);font-size:.8125rem;pointer-events:none}.asset-amount-input{width:100%;padding:.6875rem .75rem .6875rem 1.625rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:.875rem;font-family:inherit;text-align:right;transition:all .2s ease}.asset-amount-input:hover{border-color:var(--border-accent)}.asset-amount-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.asset-amount-input::placeholder{color:var(--text-muted)}.percentage-display{width:56px;padding:.6875rem .5rem;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--accent-primary);font-size:.8125rem;font-weight:600;font-family:inherit;text-align:center;flex-shrink:0}.remove-btn{display:flex;align-items:center;justify-content:center;width:32px;height:32px;background:transparent;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .2s ease;flex-shrink:0}.remove-btn:hover:not(:disabled){background:var(--error-bg);border-color:var(--error);color:var(--error)}.remove-btn:disabled{opacity:.25;cursor:not-allowed}.add-btn{display:flex;align-items:center;justify-content:center;gap:.5rem;width:100%;padding:.75rem 1rem;background:transparent;border:1px dashed var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.8125rem;font-weight:500;font-family:inherit;cursor:pointer;transition:all .2s ease}.add-btn:hover{border-color:var(--accent-primary);color:var(--accent-primary);background:var(--accent-glow)}.add-btn svg{opacity:.7}.total-row{display:flex;justify-content:space-between;align-items:center;padding:1rem 1.125rem;background:linear-gradient(135deg,#b8956c14,#b8956c08);border-radius:var(--radius-md);border:1px solid var(--border-accent);margin-top:.5rem}.total-label{font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.06em}.total-value{font-size:1.125rem;font-weight:600;color:var(--accent-secondary);font-variant-numeric:tabular-nums;letter-spacing:-.02em}@media(max-width:480px){.asset-inputs{flex-wrap:wrap}.asset-name-input{width:100%}.amount-input-wrapper{flex:1}.percentage-display{width:50px}}.legend{width:100%;max-width:380px;display:flex;flex-direction:column;gap:.5rem;padding:1.125rem;background:#23283080;border-radius:var(--radius-md);border:1px solid var(--border-subtle);margin:0 auto}.legend-item{display:flex;align-items:center;justify-content:space-between;gap:1rem;padding:.5rem 0;border-bottom:1px solid var(--border-subtle)}.legend-item:last-child{border-bottom:none}.legend-left{display:flex;align-items:center;gap:.75rem;flex-shrink:0;min-width:120px}.legend-color{width:14px;height:14px;border-radius:4px;flex-shrink:0;box-shadow:0 2px 4px #0003}.legend-name{font-size:.875rem;font-weight:500;color:var(--text-primary);white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:130px}.legend-right{display:flex;align-items:center;gap:.875rem;flex:1;min-width:0}.legend-bar-container{flex:1;height:7px;background:#ffffff0f;border-radius:4px;overflow:hidden}.legend-bar{height:100%;border-radius:4px;transition:width .4s ease}.legend-percentage{font-size:.875rem;font-weight:600;color:var(--accent-secondary);font-variant-numeric:tabular-nums;min-width:52px;text-align:right}@media(max-width:480px){.legend{max-width:100%}.legend-bar-container{display:none}.legend-name{max-width:140px}}.chart-wrapper{display:flex;flex-direction:column;align-items:center;gap:1.25rem;width:100%}.chart-canvas-wrapper{position:relative;width:100%;filter:drop-shadow(0 8px 24px rgba(0,0,0,.25))}.doughnut-wrapper,.polar-wrapper{max-width:320px;aspect-ratio:1;display:flex;align-items:center;justify-content:center}.polar-with-legend{max-width:100%;aspect-ratio:auto;min-height:300px}.bar-wrapper{height:220px;max-width:100%;display:flex;align-items:center;justify-content:center}.treemap-wrapper{max-width:360px;aspect-ratio:1.2;display:flex;align-items:center;justify-content:center}.treemap-canvas{width:100%;height:100%}.stacked-wrapper{height:80px;max-width:100%;position:relative;display:flex;align-items:center;justify-content:center}.stacked-labels{position:absolute;top:50%;left:0;right:0;height:0;pointer-events:none}.stacked-label{position:absolute;transform:translate(-50%,-50%)}.stacked-label-percent{font-size:.75rem;font-weight:600}.chart-center-label{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);display:flex;flex-direction:column;align-items:center;justify-content:center;text-align:center;pointer-events:none;max-width:55%}.center-title{font-size:1.1rem;font-weight:600;color:var(--text-primary);line-height:1.2;letter-spacing:-.01em;word-wrap:break-word;overflow-wrap:break-word}.center-percentage{font-size:1.75rem;font-weight:600;color:var(--text-primary);line-height:1;letter-spacing:-.02em}.center-text{font-size:.625rem;font-weight:400;color:var(--text-muted);text-transform:uppercase;letter-spacing:.12em;margin-top:.25rem}.button-group{display:flex;gap:.5rem;width:100%;max-width:360px}.copy-btn,.download-btn{display:flex;align-items:center;justify-content:center;gap:.375rem;flex:1;padding:.75rem 1rem;border:none;border-radius:var(--radius-sm);font-size:.8125rem;font-weight:500;font-family:inherit;letter-spacing:.01em;cursor:pointer;transition:all .2s ease}.copy-btn{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-muted) 100%);color:#1a1d24;box-shadow:0 2px 8px #b8956c33}.download-btn{background:var(--bg-secondary);color:var(--text-primary);border:1px solid var(--border-subtle)}.copy-btn:hover:not(:disabled){transform:translateY(-1px);box-shadow:0 4px 16px #b8956c4d}.download-btn:hover:not(:disabled){transform:translateY(-1px);border-color:var(--accent-primary);background:#dd89501a}.copy-btn:active:not(:disabled),.download-btn:active:not(:disabled){transform:translateY(0)}.copy-btn:disabled,.download-btn:disabled{background:var(--bg-secondary);color:var(--text-muted);cursor:not-allowed;box-shadow:none;border-color:var(--border-subtle)}.copy-btn.success{background:linear-gradient(135deg,var(--success) 0%,#5a8a6a 100%)}.download-btn.success{background:var(--success);color:#1a1d24;border-color:var(--success)}.copy-btn svg,.download-btn svg{flex-shrink:0}@media(max-width:400px){.button-group{flex-direction:column}}.chart-empty{display:flex;flex-direction:column;align-items:center;justify-content:center;gap:.875rem;padding:3rem 2rem;text-align:center;color:var(--text-muted);background:#23283066;border-radius:var(--radius-md);border:1px dashed var(--border-subtle);width:100%}.empty-icon{font-size:2.5rem;opacity:.4}.chart-empty p{font-size:.8125rem;max-width:180px;line-height:1.5}@media(max-width:640px){.doughnut-wrapper,.polar-wrapper{max-width:280px}.treemap-wrapper{max-width:300px}.center-percentage{font-size:1.5rem}.copy-btn{max-width:100%}}.chart-selector{display:flex;gap:.375rem;padding:.375rem;background:var(--bg-secondary);border-radius:var(--radius-md);border:1px solid var(--border-subtle);width:fit-content;margin:0 auto 1.5rem}.chart-option{display:flex;flex-direction:column;align-items:center;gap:.25rem;padding:.625rem .875rem;background:transparent;border:none;border-radius:var(--radius-sm);color:var(--text-muted);cursor:pointer;transition:all .2s ease;min-width:56px}.chart-option:hover{color:var(--text-secondary);background:#ffffff08}.chart-option.active{background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-muted) 100%);color:#1a1d24;box-shadow:0 2px 8px #b8956c40}.chart-option-icon{font-size:1.125rem;line-height:1}.chart-option-label{font-size:.625rem;font-weight:500;text-transform:uppercase;letter-spacing:.04em}@media(max-width:480px){.chart-selector{width:100%;justify-content:center}.chart-option{flex:1;min-width:0;padding:.5rem .375rem}.chart-option-label{font-size:.5625rem}}.app{min-height:100vh;display:flex;flex-direction:column}.header{padding:1.25rem 2rem;border-bottom:1px solid var(--border-subtle);background:#282d36b3;-webkit-backdrop-filter:blur(20px);backdrop-filter:blur(20px);position:sticky;top:0;z-index:100}.header-content{max-width:1400px;margin:0 auto;display:flex;align-items:center;gap:1rem}.logo{display:flex;align-items:center;gap:.625rem}.logo-icon{width:36px;height:36px;background:linear-gradient(135deg,var(--accent-primary) 0%,var(--accent-muted) 100%);border-radius:var(--radius-sm);display:flex;align-items:center;justify-content:center;font-size:1rem;box-shadow:var(--shadow-glow)}.logo h1{font-size:1.25rem;font-weight:500;letter-spacing:-.02em;color:var(--text-primary)}.header-tagline{color:var(--text-muted);font-size:.8125rem;margin-left:auto;font-weight:300;letter-spacing:.02em}.main-content{flex:1;max-width:1400px;margin:0 auto;padding:2.5rem 2rem;width:100%;display:grid;grid-template-columns:1fr 1fr;gap:2.5rem;align-items:start}.panel{background:#282d3699;border:1px solid var(--border-subtle);border-radius:var(--radius-lg);padding:1.75rem;box-shadow:var(--shadow-md);-webkit-backdrop-filter:blur(10px);backdrop-filter:blur(10px);transition:all .3s ease}.panel:hover{border-color:var(--border-accent);box-shadow:var(--shadow-lg),var(--shadow-glow)}.panel-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem;padding-bottom:1rem;border-bottom:1px solid var(--border-subtle)}.panel-title{font-size:.9375rem;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:.5rem;letter-spacing:.03em;text-transform:uppercase}.panel-title-icon{font-size:.875rem;opacity:.6}.title-input-wrapper{margin-bottom:1.25rem}.title-label{display:block;font-size:.75rem;font-weight:500;color:var(--text-muted);text-transform:uppercase;letter-spacing:.05em;margin-bottom:.5rem}.title-input{width:100%;padding:.75rem 1rem;background:var(--bg-secondary);border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-primary);font-size:1rem;font-family:inherit;font-weight:500;transition:all .2s ease}.title-input:hover{border-color:var(--border-accent)}.title-input:focus{outline:none;border-color:var(--accent-primary);box-shadow:0 0 0 3px var(--accent-glow)}.title-input::placeholder{color:var(--text-muted);font-weight:400}.status-actions{display:flex;align-items:center;gap:.75rem}.status-badge{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border-radius:9999px;font-size:.6875rem;font-weight:600;text-transform:uppercase;letter-spacing:.06em}.reset-btn{display:inline-flex;align-items:center;gap:.375rem;padding:.375rem .625rem;background:#64646e33;border:1px solid var(--border-subtle);border-radius:var(--radius-sm);color:var(--text-muted);font-size:.6875rem;font-weight:500;cursor:pointer;transition:all .2s ease;text-transform:uppercase;letter-spacing:.04em}.reset-btn:hover{background:#c47a7a26;border-color:#c47a7a4d;color:var(--error)}.reset-btn svg{opacity:.7}.reset-btn:hover svg{opacity:1}.status-badge.valid{background:var(--success-bg);color:var(--success);border:1px solid rgba(107,155,122,.2)}.status-badge.invalid{background:var(--error-bg);color:var(--error);border:1px solid rgba(196,122,122,.2)}.status-dot{width:5px;height:5px;border-radius:50%;animation:pulse 2.5s ease-in-out infinite}.status-badge.valid .status-dot{background:var(--success)}.status-badge.invalid .status-dot{background:var(--error)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.chart-panel{position:sticky;top:100px}.chart-container{display:flex;flex-direction:column;align-items:center;gap:1.5rem}@media(max-width:1024px){.main-content{grid-template-columns:1fr}.chart-panel{position:static}}@media(max-width:640px){.header{padding:1rem}.header-content{flex-wrap:wrap}.header-tagline{width:100%;margin-left:0;margin-top:.5rem}.main-content{padding:1.25rem 1rem;gap:1.25rem}.panel{padding:1.25rem}}
