: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:block;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: dark){:root{color:#213547;background-color:#fff}a:hover{color:#747bff}button{background-color:#f9f9f9}}.login-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#812a89}.login-form{background:#ff6cdc;padding:2rem 2.5rem;border-radius:8px;box-shadow:0 2px 16px #00000014;display:flex;flex-direction:column;gap:1rem;min-width:300px}.login-form h2{margin:0 0 1rem;text-align:center}.login-form input{padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.login-btn{padding:.5rem;background:#646cff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.login-btn:hover{background:#535bf2}.new-bank-btn{background:none;color:#812a89;border:none;font-size:1rem;text-decoration:underline}@media (max-width: 440px){.login-form{min-width:0;width:100%;max-width:95vw;padding:1rem .5rem;box-sizing:border-box;border-radius:0;box-shadow:none}.login-form input,.login-btn{font-size:.95rem;padding:.5rem .4rem}}.dashboard-root{width:100%;max-width:1280px;margin:0 auto}.dashboard-layout{display:flex;flex-direction:row;gap:1rem;min-height:300px}.dashboard-sidepanel{background:#57225c;border-radius:8px;padding:1rem;min-width:350px;flex:1 1 120px;box-shadow:0 1px 4px #00000008;touch-action:none;position:relative;transition:transform .3s cubic-bezier(.4,0,.2,1),right .3s cubic-bezier(.4,0,.2,1);flex:0 0 300px}.dashboard-sidepanel--right{width:350px;position:fixed;top:0;right:0;height:100vh;z-index:1002;transform:translate(100%);box-shadow:-2px 0 12px #0000001f;border-radius:8px 0 0 8px;background:#57225c;padding-top:2rem}.dashboard-sidepanel--right.dashboard-sidepanel--visible{transform:translate(0)}.dashboard-main{flex:2 1 300px;background:#812a89;border-radius:8px;padding:1rem;box-shadow:0 1px 4px #0000000a}.dashboard-sidepanel-button{position:fixed;top:1.2rem;width:40px;height:40px;background:#ff6cdc;border:none;border-radius:50%;box-shadow:0 1px 4px #00000014;flex-direction:column;justify-content:center;align-items:center;z-index:1004;cursor:pointer;padding:0;transition:background .2s}.dashboard-sidepanel-button--right{display:flex;right:1.2rem}.dashboard-sidepanel-button--left{display:none}.dashboard-admin-section{margin-top:1rem;border:3px dotted #3d1540;border-radius:12px}.dashboard-settings-button{padding:12px 24px;background-color:#bd3f9f;color:#fff;border:none;border-radius:4px;cursor:pointer;transition:background-color .2s;margin-bottom:1rem;width:280px;transition:background-color .4s}.dashboard-settings-button:hover{background-color:#f058c8}@media (max-width: 900px){.dashboard-layout{flex-direction:column;gap:.5rem}.dashboard-sidepanel--left{display:block;position:fixed;left:0;top:0;height:100vh;width:80vw;max-width:400px;z-index:1002;background:#57225c;transform:translate(-100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:2px 0 12px #0000001f;border-radius:0 8px 8px 0;padding-top:2rem;min-width:300px;flex:0 0 300px}.dashboard-sidepanel--left.dashboard-sidepanel--visible{transform:translate(0)}.dashboard-sidepanel--right{right:0;left:auto;top:0;height:100vh;max-width:80vw;transform:translate(100%);transition:transform .3s cubic-bezier(.4,0,.2,1);box-shadow:-2px 0 12px #0000001f;border-radius:8px 0 0 8px;padding-top:2rem}.dashboard-sidepanel--right.dashboard-sidepanel--visible{transform:translate(0)}.dashboard-sidepanel-button--left{display:flex;left:1.2rem}}.dashboard-header{display:flex;flex-direction:column;align-items:center;text-align:center;padding:1.25rem 0rem 1.5rem;background:#812a89;border-radius:10px;box-shadow:0 2px 8px #0000000a;margin:1.5rem auto;width:100%}.dashboard-header__day{font-size:.8rem;font-weight:500;color:#cecece;margin-bottom:.25rem;letter-spacing:.5px;text-transform:uppercase}.dashboard-header__bank{font-size:2rem;font-weight:700;color:#fff;margin-bottom:.5rem;letter-spacing:.5px}.dashboard-header__capitals{display:flex;flex-direction:row;gap:2rem;width:100%;justify-content:center;align-items:center}.dashboard-header__capital{display:flex;flex-direction:column;font-size:1.05rem;color:#444;padding:0 1rem}.dashboard-header__capital-label{font-size:.95rem;color:#cecece;margin-bottom:.1rem}.dashboard-header__capital-value{font-weight:700;color:#9499f3;display:flex;align-items:center;justify-content:center;gap:.5rem}.dashboard-header__capital--clickable{background:none;border:2px solid rgba(148,153,243,.2);font-family:inherit;cursor:pointer;padding:1rem 1.5rem;border-radius:12px;transition:all .2s ease;text-decoration:none;position:relative;background-color:#9499f30d}.dashboard-header__capital--clickable:hover{background-color:#9499f326;border-color:#ff6cdc66;transform:translateY(-2px);box-shadow:0 4px 12px #9499f333}.dashboard-header__capital--clickable:hover .dashboard-header__capital-value{color:#ff6cdc}.dashboard-header__capital--clickable:hover .dashboard-header__chevron-icon{transform:translate(2px)}.dashboard-header__capital--clickable:active{transform:translateY(0);box-shadow:0 2px 6px #9499f326}.dashboard-header__capital--clickable:focus{outline:none;box-shadow:0 0 0 3px #ff6cdc66}.dashboard-header__chevron-icon{transition:transform .2s ease;color:#fff9;flex-shrink:0}.dashboard-header__capital--clickable:hover .dashboard-header__chevron-icon{color:#ff6cdc}.dashboard-header__capital--loading{opacity:.6;cursor:not-allowed;pointer-events:none}.dashboard-header__capital--loading:hover{background-color:#9499f30d;border-color:#9499f333;transform:none;box-shadow:none}.dashboard-header__capital--loading .dashboard-header__capital-value{color:#9499f3}.dashboard-header__capital--loading .dashboard-header__chevron-icon{color:#fff9;transform:none}@media (max-width: 900px){.dashboard-header{padding:.5rem 0rem .7rem;max-width:100vw;margin:.5rem auto}.dashboard-header__bank{font-size:1.5rem;margin-bottom:.2rem}.dashboard-header__capitals{flex-direction:column;gap:.75rem;width:100%}.dashboard-header__capital{font-size:.95rem;padding:0 .2rem}.dashboard-header__capital-label{font-size:.85rem}.dashboard-header__capital-value{font-size:1rem}.dashboard-header__capital--clickable{padding:1rem;margin:.25rem 0;width:90%;max-width:300px}}.popup-overlay{position:fixed;top:0;left:0;right:0;bottom:0;background-color:#000000b3;display:flex;align-items:center;justify-content:center;z-index:2000;padding:1rem}.popup{background:#812a89;border-radius:12px;box-shadow:0 10px 40px #0000004d;width:100%;max-width:500px;max-height:90vh;overflow:hidden;display:flex;flex-direction:column;animation:popupFadeIn .2s ease-out}@keyframes popupFadeIn{0%{opacity:0;transform:scale(.9) translateY(-20px)}to{opacity:1;transform:scale(1) translateY(0)}}.popup__header{display:flex;justify-content:space-between;align-items:center;padding:1.5rem 1.5rem 1rem;border-bottom:1px solid rgba(255,255,255,.1)}.popup__title{margin:0;font-size:1.5rem;font-weight:600;color:#fff}.popup__close-button{background:none;border:none;font-size:2rem;color:#cecece;cursor:pointer;padding:0;width:32px;height:32px;display:flex;align-items:center;justify-content:center;border-radius:50%;transition:all .2s ease;line-height:1}.popup__close-button:hover{background-color:#ffffff1a;color:#ff6cdc}.popup__close-button:focus{outline:none;box-shadow:0 0 0 2px #ff6cdc66}.popup__content{padding:1.5rem;flex:1;overflow-y:auto}.popup__footer{padding:1rem 1.5rem 1.5rem;border-top:1px solid rgba(255,255,255,.1);display:flex;justify-content:center;gap:1rem}.popup__button{border:none;padding:.75rem 2rem;border-radius:8px;font-size:1rem;font-weight:500;cursor:pointer;transition:all .2s ease;min-width:120px}.popup__button:focus{outline:none;box-shadow:0 0 0 2px #ff6cdc66}.popup__button:active{transform:translateY(0);box-shadow:0 2px 6px #ff6cdc33}.popup__button--primary{background-color:#ff6cdc;color:#fff}.popup__button--primary:hover{background-color:#e65ac8;transform:translateY(-1px);box-shadow:0 4px 12px #ff6cdc4d}.popup__button--success{background-color:#4caf50;color:#fff}.popup__button--success:hover{background-color:#45a049;transform:translateY(-1px);box-shadow:0 4px 12px #4caf504d}.popup__button--danger{background-color:#f44336;color:#fff}.popup__button--danger:hover{background-color:#da190b;transform:translateY(-1px);box-shadow:0 4px 12px #f443364d}.popup__button--secondary{background:#ffffff1a;color:#fff;border:2px solid rgba(255,255,255,.3)}.popup__button--secondary:hover{background:#fff3;border-color:#ffffff80}.popup__button--confirm{background:#9c4aa1;color:#fff;border:2px solid #9c4aa1}.popup__button--confirm:hover:not(:disabled){background:#8a3f8f;border-color:#8a3f8f}.popup__button--confirm:disabled{opacity:.5;cursor:not-allowed}.popup__value{font-size:2.5rem;font-weight:700;color:#9499f3;text-align:center;margin-bottom:2rem}.popup__chart{background:#ffffff0d;border-radius:8px;padding:1rem;margin-top:1rem}.popup__loading,.popup__no-data{background:#ffffff0d;border:2px dashed rgba(255,255,255,.2);border-radius:8px;padding:2rem;text-align:center;color:#cecece;min-height:200px;display:flex;flex-direction:column;justify-content:center;align-items:center;margin-top:1rem}.popup__loading p,.popup__no-data p{margin:.5rem 0;line-height:1.5}.popup__chart-tooltip{background:#000000e6;border:1px solid rgba(255,255,255,.2);border-radius:6px;padding:.5rem .75rem;box-shadow:0 4px 12px #0000004d}.popup__chart-tooltip .label{margin:0 0 .25rem;font-size:.875rem;color:#cecece}.popup__chart-tooltip .value{margin:0;font-size:.9rem;font-weight:600;color:#9499f3}.popup__transaction-holdings{margin-bottom:1rem;padding:.5rem 0;font-size:.9rem;color:#e0e0e0;border-bottom:1px solid rgba(255,255,255,.1)}.popup__input-group{margin-bottom:1rem}.popup__label{display:block;margin-bottom:.5rem;font-size:.9rem;color:#e0e0e0;font-weight:600}.popup__input{width:100%;padding:.75rem;border:2px solid rgba(255,255,255,.2);border-radius:8px;background:#ffffff1a;color:#fff;font-size:1rem;transition:border-color .2s ease;box-sizing:border-box;min-width:0}.popup__input:focus{outline:none;border-color:#9c4aa1}.popup__input::placeholder{color:#ffffff80}.popup__error{margin-top:.5rem;padding:.5rem;background:#f003;border:1px solid rgba(255,0,0,.4);border-radius:4px;color:#ff6b6b;font-size:.8rem}.popup__checkbox-group{margin-top:1rem}.popup__checkbox-label{display:flex;align-items:center;cursor:pointer;font-size:.9rem;color:#e0e0e0;-webkit-user-select:none;user-select:none}.popup__checkbox{margin-right:.5rem;width:1rem;height:1rem;accent-color:#9c4aa1;cursor:pointer}@media (max-width: 900px){.popup-overlay{padding:.5rem}.popup{max-width:100%;max-height:95vh}.popup__header{padding:1rem 1rem .75rem}.popup__title{font-size:1.25rem}.popup__content{padding:1rem}.popup__footer{padding:.75rem 1rem 1rem;gap:.75rem}.popup__button{padding:.75rem 1.5rem;font-size:.95rem;min-width:100px}.popup__value{font-size:2rem;margin-bottom:1.5rem}.popup__chart{padding:.75rem}.popup__loading,.popup__no-data{padding:1.5rem;min-height:150px}.popup__chart-tooltip{padding:.5rem}.popup__chart-tooltip .label{font-size:.8rem}.popup__chart-tooltip .value{font-size:.9rem}}.investor-list{height:100%;display:flex;flex-direction:column}.investor-list__header{display:flex;justify-content:space-between;align-items:center;margin-bottom:1rem;gap:.5rem}.investor-list__title{margin:0;font-size:1.1rem;color:#ffffffe6;font-weight:600}.investor-list__sort-dropdown{background-color:#3d1540;border:1px solid #4a1a4f;border-radius:4px;color:#ffffffde;padding:.25rem .5rem;font-size:.85rem;cursor:pointer;min-width:100px;transition:border-color .2s,background-color .2s}.investor-list__sort-dropdown:hover{border-color:#ff6cdc;background-color:#4a1a4f}.investor-list__sort-dropdown:focus{outline:none;border-color:#ff6cdc;box-shadow:0 0 0 2px #ff6cdc33}.investor-list__sort-dropdown option{background-color:#3d1540;color:#ffffffde}.investor-list__items{flex:1;overflow-y:auto;display:flex;flex-direction:column;gap:.5rem}.investor-list__empty{text-align:center;color:#fff9;font-style:italic;padding:2rem 1rem;font-size:.9rem}.investor-list__item{background-color:#3d1540;border:1px solid #4a1a4f;border-radius:6px;padding:.75rem;transition:background-color .2s,border-color .2s}.investor-list__name{font-size:.9rem;font-weight:500;color:#ffffffe6;margin-bottom:.25rem}.investor-list__amount{font-size:.85rem;color:#ff6cdc;font-weight:600}@media (max-width: 900px){.investor-list__header{flex-direction:column;align-items:stretch;gap:.75rem}.investor-list__title{font-size:1.2rem;text-align:center}.investor-list__sort-dropdown{min-width:auto;width:100%}.investor-list__item{padding:.6rem}.investor-list__name{font-size:.85rem}.investor-list__amount{font-size:.8rem}}.investor-list__items::-webkit-scrollbar{width:4px}.investor-list__items::-webkit-scrollbar-track{background:#3d1540;border-radius:2px}.investor-list__items::-webkit-scrollbar-thumb{background:#ff6cdc;border-radius:2px}.investor-list__items::-webkit-scrollbar-thumb:hover{background:#e65ac8}.asset-list{display:flex;flex-direction:column;padding:1rem;max-width:600px;margin:0 auto;flex-shrink:0}.asset-list--empty{justify-content:center;align-items:center}.asset-list__empty-message{color:#fff9;font-size:1.1rem;text-align:center;font-style:italic}.asset-list__header{margin-bottom:1.5rem}.asset-list__title{margin:0;font-size:1.5rem;color:#ffffffe6;font-weight:600;text-align:center}.asset-list__items{overflow-y:auto;display:flex;flex-direction:column;gap:.75rem;max-height:400px}.asset-list__item{background-color:#3d1540;border:1px solid #4a1a4f;border-radius:8px;padding:1rem;transition:background-color .2s,border-color .2s;display:flex;justify-content:space-between;align-items:center;gap:1rem}.asset-list__item:hover{background-color:#4a1a4f;border-color:#ff6cdc}.asset-list__content{flex:1;display:flex;flex-direction:column;gap:.25rem}.asset-list__type{font-size:1rem;font-weight:500;color:#ffffffe6}.asset-list__amount{font-size:.9rem;color:#ff6cdc;font-weight:600;display:flex;align-items:center;gap:.3rem}.asset-list__pending{font-size:.9rem;font-weight:600;padding:.1rem .3rem;border-radius:4px;display:inline-block}.asset-list__pending--positive{color:#22c55e;background-color:#22c55e1a}.asset-list__pending--negative{color:#ef4444;background-color:#ef44441a}.asset-list__button{background-color:#ff6cdc;border:none;border-radius:6px;width:40px;height:40px;display:flex;align-items:center;justify-content:center;font-size:1.2rem;cursor:pointer;transition:background-color .2s,transform .1s;flex-shrink:0}.asset-list__button:hover{background-color:#e65ac8;transform:scale(1.05)}.asset-list__button:active{transform:scale(.95)}.asset-list__button:focus{outline:none;box-shadow:0 0 0 2px #ff6cdc66}.asset-list{border:1px solid rgba(255,108,220,.3);border-radius:8px;margin-top:1rem}.asset-list__header{margin-bottom:0}.asset-list__items{padding-top:1rem}.dashboard-assets-toggle-button{background:none;border:none;color:#ffffffe6;font-size:1.2rem;cursor:pointer;display:flex;align-items:center;padding:0;width:100%;font-weight:600}.dashboard-assets-toggle-button:disabled{color:#ffffff80;cursor:not-allowed}.dashboard-assets-toggle-text{flex-grow:1;text-align:left}.dashboard-assets-toggle-icon{transition:transform .2s ease;transform:rotate(0);flex-shrink:0}.dashboard-assets-toggle-icon.rotated{transform:rotate(90deg)}.asset-list__chart-section{display:flex;align-items:center;gap:.75rem;flex-shrink:0}.asset-list__performance{display:flex;flex-direction:column;gap:.125rem;font-size:.75rem;color:#fffc;min-width:3.5rem}.asset-list__performance-item{display:flex;gap:.25rem}.asset-list__performance-percentage{font-weight:700}.asset-list__performance-percentage--positive{color:#22c55e}.asset-list__performance-percentage--negative{color:#ef4444}.asset-list__performance-percentage--neutral{color:#fffc}.asset-list__loading{display:flex;align-items:center;justify-content:center;width:50px;height:36px;color:#fff9;font-size:.75rem}@media (max-width: 900px){.asset-list{padding:.75rem}.asset-list__title{font-size:1.3rem}.asset-list__item{padding:.75rem;gap:.75rem}.asset-list__type{font-size:.9rem}.asset-list__amount{font-size:.85rem}.asset-list__button{width:36px;height:36px;font-size:1.1rem}}.asset-list__items::-webkit-scrollbar{width:6px}.asset-list__items::-webkit-scrollbar-track{background:#3d1540;border-radius:3px}.asset-list__items::-webkit-scrollbar-thumb{background:#ff6cdc;border-radius:3px}.asset-list__items::-webkit-scrollbar-thumb:hover{background:#e65ac8}.asset-list__item--cash{border:2px solid #ffd700;background-color:#3d1540;position:relative}.asset-list__item--cash .asset-list__amount{display:block}.loading-popup{min-height:200px;display:flex;flex-direction:column;justify-content:center}.loading-popup__message{display:flex;flex-direction:column;align-items:center;gap:1rem;padding:1rem;font-size:1.1rem;text-align:center}.loading-popup__message--success{color:#22c55e}.loading-popup__message--error{color:#ef4444}.loading-popup__spinner{width:40px;height:40px;border:4px solid #f3f4f6;border-top:4px solid #3b82f6;border-radius:50%;animation:loading-spin 1s linear infinite}@keyframes loading-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.new-bank-container{display:flex;flex-direction:column;align-items:center;justify-content:center;min-height:100vh;background:#812a89}.new-bank-form{background:#ff6cdc;padding:2rem 2.5rem;border-radius:8px;box-shadow:0 2px 16px #00000014;display:flex;flex-direction:column;gap:1rem;min-width:300px}.new-bank-form h2{margin:0 0 1rem;text-align:center}.new-bank-form label{display:flex;flex-direction:column;font-size:1rem;color:#222}.new-bank-form input{padding:.5rem;border:1px solid #ccc;border-radius:4px;font-size:1rem}.confirm-btn{padding:.5rem;background:#646cff;color:#fff;border:none;border-radius:4px;font-size:1rem;cursor:pointer;transition:background .2s}.confirm-btn:hover{background:#535bf2}.back-login-btn{background:none;color:#812a89;border:none;font-size:1rem;text-decoration:underline}.back-login-btn:hover{background:#535bf2}.error-msg{color:#6b1e14;text-align:center;margin-top:.5rem}.success-msg{color:#185f18;text-align:center;margin-top:.5rem}.confirm-btn:disabled{cursor:not-allowed;opacity:.7}@media (max-width: 440px){.new-bank-form{min-width:0;width:100%;max-width:95vw;padding:1rem .5rem;box-sizing:border-box;border-radius:0;box-shadow:none}.new-bank-form input,.confirm-btn,.back-login-btn{font-size:.95rem;padding:.5rem .4rem}}#root{max-width:1280px;margin:0 auto;padding:1rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.read-the-docs{color:#888}
