:root{--bg: #0a0a0a;--surface: #141414;--surface-strong: #1a1a1a;--line: #262626;--text: #f5f5f5;--text-soft: #8b8b8b;--brand: #10b981;--brand-soft: rgba(16, 185, 129, .12);--danger: #ef4444;--danger-soft: rgba(239, 68, 68, .12);--radius: 12px;--shadow: 0 1px 3px rgba(0, 0, 0, .3);--sidebar-width: 256px}*{box-sizing:border-box}body{margin:0;background:var(--bg);color:var(--text);font-family:-apple-system,BlinkMacSystemFont,Segoe UI,system-ui,sans-serif;min-height:100vh}.layout{display:flex;min-height:100vh}.main-content{flex:1;margin-left:var(--sidebar-width);min-height:100vh;display:flex;flex-direction:column}.page-header{padding:1.25rem 2rem 0}.page-title{margin:0;font-size:1.2rem;font-weight:700;color:var(--text)}.page-body{flex:1;padding:1rem 2rem 2rem;max-width:1100px;width:100%}.sidebar{position:fixed;top:0;left:0;bottom:0;width:var(--sidebar-width);background:var(--surface);border-right:1px solid var(--line);display:flex;flex-direction:column;z-index:100;overflow-y:auto}.sidebar-top{flex:1;padding:1.25rem .75rem}.sidebar-brand{display:flex;align-items:center;gap:.75rem;padding:.5rem .75rem;margin-bottom:1.5rem;cursor:pointer}.sidebar-logo{width:36px;height:36px;border-radius:10px;object-fit:cover}.sidebar-brand-text{font-weight:700;font-size:1.1rem;color:var(--text)}.sidebar-section{margin-bottom:1.25rem}.sidebar-section-title{font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase;color:var(--text-soft);padding:0 .75rem;margin-bottom:.4rem}.sidebar-item{display:flex;align-items:center;gap:.65rem;width:100%;padding:.55rem .75rem;border:none;border-radius:8px;background:transparent;color:var(--text-soft);font-size:.9rem;font-weight:500;cursor:pointer;transition:all .15s ease}.sidebar-item:hover{background:var(--brand-soft);color:var(--text);transform:none}.sidebar-item.active{background:var(--brand-soft);color:var(--brand);font-weight:600}.sidebar-bottom{padding:.75rem;border-top:1px solid var(--line)}.sidebar-account{display:flex;align-items:center;gap:.6rem;padding:.55rem .75rem;border-radius:8px;cursor:pointer;transition:background .15s ease}.sidebar-account:hover{background:#ffffff0d}.sidebar-avatar{width:28px;height:28px;border-radius:50%;background:var(--brand-soft);display:flex;align-items:center;justify-content:center;color:var(--brand);flex-shrink:0}.sidebar-account-name{flex:1;font-size:.88rem;font-weight:500;color:var(--text)}.sidebar-chevron{color:var(--text-soft);transition:transform .2s ease}.sidebar-chevron.open{transform:rotate(180deg)}.sidebar-account-menu{padding:.25rem 0;margin-top:.25rem}.sidebar-account-menu button{display:flex;align-items:center;gap:.5rem;width:100%;padding:.45rem .75rem;border:none;border-radius:6px;background:transparent;color:var(--text-soft);font-size:.85rem;cursor:pointer}.sidebar-account-menu button:hover{background:#ffffff0d;color:var(--text);transform:none}.sidebar-mobile-toggle{display:none;position:fixed;top:1rem;left:1rem;z-index:150;padding:.5rem;border-radius:8px;background:var(--surface);border:1px solid var(--line);color:var(--text);cursor:pointer}.sidebar-overlay{display:none}.dashboard-toolbar{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;justify-content:flex-end}.dashboard-toolbar .ghost{padding:.35rem .5rem}.dashboard-toolbar .toggle-group{cursor:pointer}.dashboard-stats{display:grid;grid-template-columns:repeat(4,1fr);gap:.75rem;margin-bottom:1.25rem}.stat-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.85rem 1rem}.stat-card-header{display:flex;align-items:center;gap:.35rem;color:var(--text-soft);font-size:.78rem;font-weight:600}.stat-card-body{display:flex;align-items:center;justify-content:space-between;margin-top:.5rem}.stat-card-value{font-size:1.15rem;font-weight:700}.stat-card-note{margin-top:.25rem;font-size:.75rem;color:var(--text-soft)}.dashboard-holdings-panel{margin-top:0}p{margin:.4rem 0 0;color:var(--text-soft)}h1{margin:0}.panel{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:1rem;margin-top:1rem}.panel.compact{padding:.85rem 1rem}.panel-title{font-size:.95rem;font-weight:700;color:var(--text)}.panel-row{display:flex;justify-content:space-between;align-items:center;gap:.7rem}.panel-row.space-bottom{margin-bottom:.7rem}.panel-actions{display:flex;gap:.45rem}button,input,select{font:inherit}button{display:inline-flex;align-items:center;gap:.4rem;border-radius:8px;border:1px solid transparent;padding:.5rem .85rem;background:var(--brand);color:#fff;cursor:pointer;font-weight:600;font-size:.88rem;transition:all .15s ease}button:hover{opacity:.9;transform:translateY(-1px)}button:disabled{opacity:.5;cursor:not-allowed}button.ghost{background:transparent;color:var(--text);border-color:var(--line)}button.ghost:hover{background:#ffffff0d;border-color:var(--text-soft)}button.ghost.danger{color:var(--danger)}button.ghost.danger:hover{background:var(--danger-soft)}input{background:var(--surface-strong);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:.55rem .7rem;transition:border-color .15s ease}input:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}input::placeholder{color:var(--text-soft)}select{background:var(--surface-strong);border:1px solid var(--line);color:var(--text);border-radius:8px;padding:.55rem .7rem}select:focus{outline:none;border-color:var(--brand);box-shadow:0 0 0 3px var(--brand-soft)}.session-form{margin-top:.8rem;display:grid;grid-template-columns:1fr 1fr auto;gap:.55rem}.accounts-header{display:flex;align-items:center;gap:.5rem;margin-bottom:.75rem;justify-content:flex-end}.connect-prompt{text-align:center;padding:2rem 1rem;color:var(--text-soft)}.connect-prompt h3{margin:.75rem 0 .5rem;color:var(--text);font-size:1.05rem}.connect-prompt p{max-width:400px;margin:0 auto;line-height:1.5}.brokerages-list{display:flex;flex-direction:column;gap:.75rem}.brokerage-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);overflow:hidden}.brokerage-header{display:flex;align-items:center;justify-content:space-between;padding:.85rem 1rem;cursor:pointer;-webkit-user-select:none;user-select:none}.brokerage-header:hover{background:var(--surface-strong)}.brokerage-header-left{display:flex;align-items:center;gap:.6rem}.brokerage-chevron{transition:transform .2s;color:var(--text-soft);transform:rotate(-90deg);flex-shrink:0}.brokerage-chevron.open{transform:rotate(0)}.brokerage-name{font-weight:600;font-size:.95rem;color:var(--text)}.brokerage-meta{font-size:.78rem;color:var(--text-soft);margin-top:.1rem}.brokerage-header-right{text-align:right}.brokerage-total{font-weight:600;font-size:.95rem;color:var(--text)}.brokerage-status{display:flex;align-items:center;justify-content:flex-end;gap:.35rem;font-size:.78rem;color:var(--text-soft);margin-top:.1rem}.status-dot{width:7px;height:7px;border-radius:50%;background:var(--text-soft)}.status-dot.active{background:var(--brand)}.brokerage-disconnect-btn{padding:.15rem .25rem;margin-left:.2rem;opacity:0;transition:opacity .15s;font-size:.7rem;line-height:1}.brokerage-header:hover .brokerage-disconnect-btn{opacity:1}.brokerage-accounts{border-top:1px solid var(--line)}.account-row{display:flex;align-items:center;justify-content:space-between;padding:.65rem 1rem .65rem 2.6rem;border-bottom:1px solid var(--line)}.account-row:last-child{border-bottom:none}.account-row-info{display:flex;align-items:center;gap:.5rem}.account-row-name{font-weight:500;font-size:.88rem;color:var(--text)}.account-row-alias{font-weight:400;color:var(--text-soft)}.account-row-number{font-size:.78rem;color:var(--text-soft)}.account-row-stats{display:flex;align-items:center;gap:1rem;text-align:right}.account-row-value{font-weight:600;font-size:.88rem;color:var(--text)}.account-row-holdings{font-size:.78rem;color:var(--text-soft);min-width:80px}.toggle-group{display:inline-flex;padding:.2rem;background:var(--surface-strong);border-radius:999px;border:1px solid var(--line)}.toggle-group button{border:0;background:transparent;color:var(--text-soft);border-radius:999px;padding:.38rem .7rem;font-size:.82rem}.toggle-group button.active{background:var(--brand);color:#fff}.toggle-group button:hover{transform:none}.filters-row{margin-top:.85rem;display:grid;grid-template-columns:repeat(2,minmax(0,1fr));gap:.65rem}.filter-field{display:grid;gap:.28rem}.filter-field label{color:var(--text-soft);font-size:.82rem;font-weight:600}.table-wrap{margin-top:.7rem;overflow:hidden}.table-scroll{width:100%;overflow-y:auto;overflow-x:hidden;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface)}.table-scroll::-webkit-scrollbar{width:6px}.table-scroll::-webkit-scrollbar-track{background:var(--surface)}.table-scroll::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.activity-table-scroll{height:620px}.table-height-handle{margin-top:.3rem;height:14px;cursor:ns-resize;display:flex;align-items:center;justify-content:center;-webkit-user-select:none;user-select:none}.table-height-grip{width:66px;height:5px;border-radius:999px;background:var(--line)}.table-height-handle:hover .table-height-grip{background:var(--text-soft)}table{width:100%;table-layout:fixed;border-collapse:collapse;min-width:0}th,td{border-bottom:1px solid var(--line);text-align:left;padding:.5rem .4rem;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;font-size:.88rem}th{color:var(--text-soft);font-weight:600;font-size:.84rem;position:sticky;top:0;background:var(--surface-strong);z-index:1}.resizable-th{padding:0}.th-inner{position:relative;display:flex;align-items:center;justify-content:space-between;padding:.6rem .75rem .6rem .4rem;min-height:38px}.resize-handle{position:absolute;right:0;top:0;bottom:0;width:10px;cursor:col-resize;border-right:2px solid transparent}.resize-handle:hover{border-right-color:var(--brand)}tr.clickable-row{cursor:pointer;transition:background .12s ease}tr.clickable-row:hover{background:#ffffff0a}.trend-up{color:var(--brand)}.trend-down{color:var(--danger)}.trend-text{font-weight:600}.pnl-positive-value{color:var(--brand)}.pnl-negative-value{color:var(--danger)}.status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.9rem;margin:1rem 0}.status-card{background:var(--surface);border:1px solid var(--line);border-radius:var(--radius);padding:.85rem .95rem .8rem}.status-header{display:inline-flex;align-items:center;gap:.4rem;color:var(--text-soft);font-weight:600;font-size:.82rem}.status-value{margin-top:.4rem;font-size:1.25rem;font-weight:700}.status-note{color:var(--text-soft);margin-top:.24rem;font-size:.82rem}.pie-wrap{margin-top:1.5rem;margin-bottom:1rem}.pie-chart-layout{display:flex;gap:3rem;align-items:center;justify-content:center;padding:0 2rem;min-height:300px}.pie-chart-container{flex:0 0 35%;max-width:350px}.pie-legend-container{flex:0 0 60%;max-width:600px;min-height:300px;max-height:350px;overflow-y:auto;padding-right:.5rem}.pie-legend-container::-webkit-scrollbar{width:6px}.pie-legend-container::-webkit-scrollbar-track{background:var(--surface);border-radius:3px}.pie-legend-container::-webkit-scrollbar-thumb{background:var(--line);border-radius:3px}.legend-grid{display:grid;gap:.6rem;padding:.75rem}.legend-item{display:grid;grid-template-columns:auto minmax(120px,1fr) auto auto;align-items:center;gap:.65rem;padding:.65rem .75rem;border:1px solid var(--line);border-radius:10px;background:var(--surface-strong)}.legend-item>span:nth-child(2){white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.legend-dot{width:12px;height:12px;border-radius:999px}.legend-item.clickable{cursor:pointer}.loading{display:inline-flex;align-items:center;gap:.55rem;margin-top:1rem;color:var(--text-soft)}.spinner{animation:spin 1.1s linear infinite}.error-banner{margin-top:1rem;background:var(--danger-soft);border:1px solid rgba(239,68,68,.3);color:var(--danger);padding:.7rem .75rem;border-radius:var(--radius)}.warning p{display:flex;align-items:center;gap:.45rem;margin:.35rem 0;color:#d4a930}.reveal{animation:revealUp .4s ease both}.delayed-1{animation-delay:50ms}.delayed-2{animation-delay:.1s}.delayed-3{animation-delay:.15s}.delayed-4{animation-delay:.2s}@keyframes revealUp{0%{opacity:0;transform:translateY(6px)}to{opacity:1;transform:translateY(0)}}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.page-body{animation:fadeIn .25s ease both}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}.settings-tabs{display:flex;gap:.25rem;margin-bottom:1rem;border-bottom:1px solid var(--line);padding-bottom:.5rem}.settings-tab{padding:.45rem 1rem;border:none;border-radius:6px;background:transparent;color:var(--text-soft);font-weight:600;cursor:pointer}.settings-tab:hover{background:#ffffff0a;transform:none}.settings-tab.active{background:var(--brand-soft);color:var(--brand)}.settings-section{margin-top:0}.settings-group{display:flex;flex-direction:column;gap:0}.settings-row{display:flex;justify-content:space-between;align-items:center;gap:1rem;padding:1rem 0;border-bottom:1px solid var(--line)}.settings-row:last-child{border-bottom:none}.settings-label{font-weight:600;font-size:.95rem;color:var(--text)}.settings-description{font-size:.82rem;color:var(--text-soft);margin-top:.15rem}.account-alias-input{width:160px;padding:.4rem .6rem;background:var(--surface);border:1px solid var(--line);border-radius:6px;color:var(--text);font-size:.9rem}.account-alias-input:focus{border-color:var(--brand);outline:none}.account-alias-display{color:var(--text-soft);font-size:.9rem}.stock-header{display:flex;justify-content:space-between;align-items:center;gap:1rem;margin-bottom:.75rem}.stock-back-btn{font-size:.84rem}.stock-identity{display:flex;align-items:baseline;gap:.5rem}.stock-symbol{font-size:1.1rem;font-weight:700}.stock-name{color:var(--text-soft);font-size:.88rem}.exchange-selector{display:flex;align-items:center;gap:.5rem;margin-left:auto}.exchange-selector label{color:var(--text-soft);font-size:.88rem;font-weight:600}.exchange-selector select{padding:.35rem .6rem;font-size:.88rem}.stock-status-grid{display:grid;grid-template-columns:repeat(3,minmax(0,1fr));gap:.75rem;margin:.75rem 0}.stock-chart-panel{margin-top:1rem}.stock-range-tabs{display:inline-flex;background:var(--surface-strong);border-radius:999px;border:1px solid var(--line);padding:.2rem;margin:0}.stock-range-tabs button{padding:.35rem .6rem;font-size:.82rem;border:0;background:transparent;color:var(--text-soft);border-radius:999px}.stock-range-tabs button.active{background:var(--brand-soft);color:var(--brand)}.stock-line-chart{min-height:200px;position:relative}.stock-chart-loading,.stock-chart-empty{display:flex;align-items:center;justify-content:center;gap:.55rem;min-height:220px;color:var(--text-soft)}.stock-two-col{display:grid;grid-template-columns:1fr 1fr;gap:1rem;margin-top:1rem}.stock-two-col>.panel{margin-top:0}.stats-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:0 1.5rem;margin-top:.75rem}.stat-item{display:flex;justify-content:space-between;align-items:baseline;padding:.6rem 0;border-bottom:1px solid var(--line)}.stat-item:last-child{border-bottom:none}.stat-day-range{grid-column:1 / -1;flex-wrap:wrap}.stat-label{color:var(--text-soft);font-size:.88rem;font-weight:600}.stat-value{color:var(--text);font-weight:600;font-size:.95rem}.day-range-bar{width:100%;margin-top:.4rem}.day-range-track{position:relative;height:4px;border-radius:2px;background:var(--line)}.day-range-fill{position:absolute;top:0;left:0;height:4px;border-radius:2px;background:var(--brand)}.day-range-dot{position:absolute;top:-3px;width:10px;height:10px;border-radius:50%;background:var(--brand);transform:translate(-50%)}.news-list{margin-top:.5rem}.news-item{display:block;padding:.7rem 0;border-bottom:1px solid var(--line);text-decoration:none;color:inherit;transition:background .15s ease}.news-item:last-child{border-bottom:none}.news-item:hover{background:#ffffff0a;margin:0 -1rem;padding:.7rem 1rem;border-radius:8px}.news-headline{font-weight:600;font-size:.92rem;color:var(--text);line-height:1.4;display:-webkit-box;-webkit-line-clamp:2;-webkit-box-orient:vertical;overflow:hidden}.news-meta{display:flex;gap:.5rem;margin-top:.3rem}.news-source{color:var(--brand);font-size:.82rem;font-weight:600}.news-time{color:var(--text-soft);font-size:.82rem}.news-empty{text-align:center;color:var(--text-soft);padding:2rem 0}.news-item-skeleton{padding:.7rem 0;border-bottom:1px solid var(--line)}.news-item-skeleton:last-child{border-bottom:none}.position-summary{margin-top:.5rem}.position-total{display:flex;justify-content:space-between;padding:.5rem 0 .7rem;font-weight:600;font-size:.95rem}.position-value{font-size:1.1rem;font-weight:700}.position-table table{table-layout:auto}.position-pie-wrap{margin-top:1rem}.related-grid{display:flex;gap:.6rem;flex-wrap:wrap;margin-top:.75rem}.related-card{display:flex;flex-direction:column;align-items:flex-start;gap:.2rem;min-width:100px;padding:.5rem .85rem;border-radius:var(--radius);border:1px solid var(--line);background:var(--surface-strong);cursor:pointer;transition:transform .15s ease}.related-card:hover{transform:translateY(-1px)}.related-symbol{font-weight:700;font-size:.92rem;color:var(--brand)}.related-value{font-size:.82rem;color:var(--text-soft)}@keyframes shimmer{0%{background-position:-200% 0}to{background-position:200% 0}}.skeleton-line{display:inline-block;height:1em;border-radius:6px;background:linear-gradient(90deg,var(--line) 25%,#333 50%,var(--line) 75%);background-size:200% 100%;animation:shimmer 1.5s ease-in-out infinite}.tooltip{border-radius:8px;border:1px solid var(--line);background:var(--surface-strong);padding:.5rem .65rem}.tooltip-label{color:var(--text-soft);font-size:.82rem}.tooltip-value{font-weight:700;margin-top:.25rem;color:var(--text)}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:2rem}.auth-card{width:100%;max-width:400px;background:var(--surface);border:1px solid var(--line);border-radius:16px;padding:2.5rem}.auth-brand{display:flex;align-items:center;gap:.75rem;margin-bottom:2rem;justify-content:center}.auth-brand img{width:40px;height:40px;border-radius:10px}.auth-brand span{font-size:1.3rem;font-weight:700}.auth-title{font-size:1.2rem;font-weight:700;margin-bottom:1.5rem;text-align:center}.auth-form{display:flex;flex-direction:column;gap:.75rem}.auth-form input{width:100%;padding:.7rem .85rem}.auth-form button[type=submit]{width:100%;padding:.7rem;justify-content:center;font-size:.95rem;margin-top:.25rem}.auth-switch{margin-top:1rem;text-align:center;font-size:.88rem;color:var(--text-soft)}.auth-switch button{background:none;border:none;color:var(--brand);cursor:pointer;padding:0;font-weight:600}.auth-switch button:hover{transform:none;text-decoration:underline}.auth-demo{margin-top:1.25rem;text-align:center}.auth-demo button{background:transparent;color:var(--text-soft);border:1px solid var(--line);width:100%;justify-content:center}.auth-demo button:hover{color:var(--text);border-color:var(--text-soft)}.auth-error{background:var(--danger-soft);color:var(--danger);padding:.5rem .7rem;border-radius:8px;font-size:.88rem;text-align:center}@media(max-width:1100px){.dashboard-stats{grid-template-columns:repeat(2,1fr)}}@media(max-width:980px){.status-grid,.stock-status-grid,.stock-two-col,.stats-grid,.session-form,.filters-row{grid-template-columns:1fr}.pie-chart-layout{flex-direction:column;align-items:center;gap:2rem;padding:0}.pie-chart-container{flex:0 0 auto;width:100%;max-width:320px}.pie-legend-container{flex:0 0 auto;width:100%;max-width:none;max-height:none;padding-right:0}}@media(max-width:768px){.sidebar{transform:translate(-100%);transition:transform .25s ease}.sidebar.open{transform:translate(0)}.sidebar-mobile-toggle{display:flex}.sidebar-overlay{display:block;position:fixed;inset:0;background:#00000080;z-index:90}.main-content{margin-left:0}.page-header{padding:3.5rem 1rem 0}.page-body{padding:1rem}.dashboard-stats{grid-template-columns:1fr}.stock-header{flex-direction:column;align-items:flex-start;gap:.5rem}.exchange-selector{width:100%;margin-left:0}.exchange-selector select{flex:1}.panel-row{flex-direction:column;align-items:flex-start}.settings-row{flex-direction:column;align-items:flex-start;gap:.5rem}}
