:root{font-family:system-ui,Avenir,Helvetica,Arial,sans-serif;line-height:1.5;font-weight:400;color-scheme:light dark;color:#ffffffde;background-color:#242424;font-synthesis:none;text-rendering:optimizeLegibility;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}a{font-weight:500;color:#646cff;text-decoration:inherit}a:hover{color:#535bf2}body{margin:0;display:flex;place-items:center;min-width:320px;min-height:100vh}h1{font-size:3.2em;line-height:1.1}button{border-radius:8px;border:1px solid transparent;padding:.6em 1.2em;font-size:1em;font-weight:500;font-family:inherit;background-color:#1a1a1a;cursor:pointer;transition:border-color .25s}button:hover{border-color:#646cff}button:focus,button:focus-visible{outline:4px auto -webkit-focus-ring-color}@media(prefers-color-scheme:light){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}*{box-sizing:border-box;margin:0;padding:0}body{font-family:system-ui,sans-serif;background:#0f1117;color:#e0e0e0;min-height:100vh}:root{--topbar-h: 72px}.app{max-width:100%;margin:0;padding:0}.top-bar{position:fixed;top:0;left:0;right:0;z-index:10;background:#0f1117;border-bottom:1px solid #2d3148;display:flex;flex-direction:column}.top-row{display:flex;align-items:center;gap:2rem;padding:0 1.5rem;height:60px;flex-shrink:0}.top-row h1{font-size:1.3rem;margin:0;white-space:nowrap}.import-btn{margin-left:auto;background:transparent;border:1px solid #4ade80;color:#4ade80;padding:.4rem 1rem;border-radius:6px;font-size:.85rem;cursor:pointer;white-space:nowrap}.import-btn:hover{background:#4ade80;color:#000}.import-btn:disabled{opacity:.5;cursor:default}.portfolio-panel{display:flex;align-items:stretch;border-top:1px solid #1a1d2e}.portfolio-table-wrap{flex:0 0 50%;overflow:auto}.portfolio-pies{flex:1;display:flex;flex-direction:column;border-left:1px solid #1a1d2e;min-width:0}.portfolio-pie{display:flex;align-items:center;justify-content:center;flex:1;position:relative;border:1px solid #2d3148;border-radius:8px;margin:6px}.pie-title{position:absolute;top:8px;left:12px;font-size:.75rem;font-weight:600;color:#aaa;text-transform:uppercase;letter-spacing:.05em;pointer-events:none}.portfolio-pie--tickers{flex:none;height:300px;overflow:visible}.portfolio-table{width:100%;border-collapse:collapse;margin:0;background:transparent;border-radius:0}.portfolio-table thead th{background:#13161f;color:#555;font-size:.72rem;text-transform:uppercase;letter-spacing:.05em;padding:.3rem 1.5rem;font-weight:600;text-align:left}.portfolio-table tbody tr{cursor:pointer;transition:background .1s}.portfolio-table tbody tr:hover td{background:#171a27}.portfolio-table tbody tr.active td{background:#1e2130}.portfolio-table tbody td{padding:.5rem 1.5rem;font-size:.9rem;border-bottom:1px solid #1a1d2e}.portfolio-table tbody tr:last-child td{border-bottom:none}.portfolio-table tfoot tr.portfolio-total td{border-top:1px solid #3d4168;padding:.45rem 1.5rem;font-size:.85rem;font-weight:600;color:#aaa;background:#13161f}.portfolio-table td.pv-value{color:#4ade80;font-weight:600}.app>.error{position:fixed;left:50vw;padding:.5rem 1.5rem;z-index:20;background:#1e2130;border:1px solid #f87171;border-radius:6px}.main-layout{display:flex;align-items:flex-start;padding-top:var(--topbar-h)}.line-chart-panel{position:fixed;top:var(--topbar-h);left:0;width:50vw;height:calc(100vh - var(--topbar-h));margin:0;border-radius:0;border-top:none;border-left:none;border-bottom:none;display:flex;flex-direction:column;padding:1.5rem}.line-chart-panel h2{flex-shrink:0}.line-chart-panel .recharts-responsive-container{flex:1!important;height:auto!important}.right-panel{margin-left:50vw;width:50vw;padding:1.5rem 1.5rem 2rem;min-width:0}h1{font-size:1.8rem;margin-bottom:1.5rem;color:#fff}.summary{background:#1e2130;border:1px solid #2d3148;border-radius:10px;padding:1.2rem 1.5rem;display:flex;justify-content:space-between;align-items:center;font-size:1rem;color:#aaa}.summary strong{font-size:1.5rem;color:#4ade80}.error{color:#f87171;margin-bottom:1rem}table{width:100%;border-collapse:collapse;margin-bottom:2rem;background:#1e2130;border-radius:10px;overflow:hidden}th,td{padding:.8rem 1rem;text-align:left}th{background:#2d3148;color:#aaa;font-size:.85rem;text-transform:uppercase;letter-spacing:.05em}tr:not(:last-child) td{border-bottom:1px solid #2d3148}button.delete{background:transparent;border:1px solid #f87171;color:#f87171;padding:.3rem .7rem;border-radius:6px;cursor:pointer;font-size:.8rem}button.delete:hover{background:#f87171;color:#000}.chart-card{background:#1e2130;border:1px solid #2d3148;border-radius:10px;padding:1.2rem 1rem .5rem;margin-bottom:1.5rem}.chart-subtitle{font-size:.75rem;color:#555;font-weight:400;margin-left:.4rem}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;flex-shrink:0}.chart-header h2{margin-bottom:0}.interval-toggle{display:flex;gap:.3rem}.interval-toggle button{background:transparent;border:1px solid #2d3148;color:#aaa;padding:.25rem .6rem;border-radius:5px;font-size:.8rem;cursor:pointer}.interval-toggle button:hover{border-color:#4ade80;color:#4ade80}.interval-toggle button.active{background:#4ade80;border-color:#4ade80;color:#000;font-weight:600}.chart-card h2{font-size:1rem;color:#aaa;margin-bottom:1rem;font-weight:500;flex-shrink:0}.chart-loading{color:#666;font-size:.9rem;padding:2rem 0;text-align:center}.chart-tooltip{background:#2d3148;border:1px solid #3d4168;border-radius:6px;padding:.5rem .8rem;display:flex;flex-direction:column;gap:2px;font-size:.9rem}.chart-tooltip strong{color:#fff}.chart-tooltip span{display:block}.login-screen{position:fixed;inset:0;display:flex;flex-direction:column;align-items:center;justify-content:center;background:#0f1117}.login-logo{max-width:260px;margin-bottom:1.5rem;border-radius:8px}.login-form{background:#1e2130;border:1px solid #2d3148;border-radius:12px;padding:2.5rem 2rem;display:flex;flex-direction:column;gap:1rem;width:320px}.login-form h1{font-size:1.3rem;margin-bottom:.5rem;text-align:center}.login-form input{background:#13161f;border:1px solid #2d3148;border-radius:6px;color:#e0e0e0;font-size:.95rem;padding:.6rem .9rem;outline:none}.login-form input:focus{border-color:#4ade80}.login-form button[type=submit]{background:#4ade80;border:none;border-radius:6px;color:#000;cursor:pointer;font-size:.95rem;font-weight:600;padding:.65rem;margin-top:.25rem}.login-form button[type=submit]:hover{background:#22c55e}.login-error{color:#f87171;font-size:.85rem;text-align:center;margin:0}.logout-btn{background:transparent;border:1px solid #555;color:#aaa;padding:.4rem .9rem;border-radius:6px;font-size:.85rem;cursor:pointer;white-space:nowrap}.logout-btn:hover{border-color:#f87171;color:#f87171}
