.app{min-height:100vh}.loading-screen{display:flex;flex-direction:column;align-items:center;justify-content:center;height:100vh;background:var(--bg);color:var(--text);gap:1rem}.loading-spinner{width:48px;height:48px;border:3px solid var(--border);border-top-color:var(--cyan);border-radius:50%;animation:spin 1s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;background:var(--bg);padding:2rem}.auth-card{width:100%;max-width:420px;background:var(--bg-card);border:1px solid var(--border);border-radius:1rem;padding:2rem}.auth-header{text-align:center;margin-bottom:2rem}.auth-header h1{font-size:1.5rem;color:var(--cyan);margin-bottom:.5rem}.auth-header p{color:var(--text-muted);font-size:.875rem}.auth-form{display:flex;flex-direction:column;gap:1rem}.form-group{display:flex;flex-direction:column;gap:.375rem}.auth-footer{margin-top:1.5rem;text-align:center;font-size:.875rem;color:var(--text-muted)}.auth-footer a{color:var(--cyan)}.layout{min-height:100vh;display:flex;flex-direction:column}.header{background:var(--bg-card);border-bottom:1px solid var(--border);padding:calc(1rem + env(safe-area-inset-top)) 0 1rem;position:sticky;top:0;z-index:100;box-shadow:var(--shadow-md)}.header-content{display:flex;align-items:center;justify-content:space-between;max-width:1400px;margin:0 auto;padding:0 1.5rem}.header-brand h1{font-size:1.25rem;color:var(--cyan);font-weight:700}.header-brand p{font-size:.75rem;color:var(--text-muted);margin-top:.25rem}.header-kpi{text-align:right}.header-kpi-label{font-size:.6875rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em}.header-kpi-value{font-size:1.5rem;font-weight:700;font-family:Space Mono,monospace;color:var(--text)}.header-kpi-sub{font-size:.75rem;color:var(--text-muted);font-family:Space Mono,monospace}.nav-bar{background:var(--bg-light);border-bottom:1px solid var(--border)}.nav-content{max-width:1400px;margin:0 auto;padding:0 1.5rem;display:flex;align-items:center;justify-content:space-between}.nav-tabs{display:flex;gap:.25rem}.nav-tab{padding:.875rem 1.25rem;font-size:.9375rem;font-weight:500;color:var(--text-muted);border-bottom:2px solid transparent;transition:color .18s,border-color .18s;position:relative}.nav-tab:hover{color:var(--text)}.nav-tab.active{color:var(--cyan);border-bottom-color:var(--cyan)}.nav-actions{display:flex;gap:.5rem;align-items:center}.btn-action{border:none;color:var(--bg);font-weight:700;letter-spacing:.02em;text-transform:uppercase;box-shadow:0 1px 2px #00000040}.btn-action-trade{background:linear-gradient(135deg,#00d4ff,#09c)}.btn-action-dividend{background:linear-gradient(135deg,#c084fc,#8b5cf6);color:#fff}.btn-action-deposit{background:linear-gradient(135deg,#00e5a0,#059669)}.btn-action:hover{filter:brightness(1.1)}.btn-icon{padding:.375rem .5rem;display:inline-flex;align-items:center;justify-content:center}.btn-spin svg,.btn-spin .spin-target{animation:spin .8s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.nav-actions-full{display:inline-flex;gap:.5rem}.nav-actions-compact{display:none}@media (max-width: 900px){.nav-actions-full{display:none}.nav-actions-compact{display:inline-flex}}.settings-dropdown{position:relative;display:inline-block}.settings-trigger{padding:.375rem .5rem}.settings-menu{position:absolute;top:calc(100% + .5rem);right:0;min-width:200px;background:var(--bg-card);border:1px solid var(--border);border-radius:.5rem;box-shadow:0 10px 30px #00000073;padding:.5rem;z-index:1000}.settings-menu-header{display:flex;align-items:center;gap:.625rem;padding:.5rem .375rem}.settings-menu-avatar{width:32px;height:32px;border-radius:50%;background:linear-gradient(135deg,var(--cyan) 0%,var(--purple) 100%);color:var(--bg);font-weight:700;display:inline-flex;align-items:center;justify-content:center;flex-shrink:0}.settings-menu-user{min-width:0}.settings-menu-username{font-weight:600;font-size:.875rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.settings-menu-muted{color:var(--text-muted);font-size:.75rem}.settings-menu-divider{height:1px;background:var(--border);margin:.375rem 0}.settings-menu-item{display:block;width:100%;text-align:left;padding:.5rem .625rem;border-radius:.375rem;color:var(--text);font-size:.875rem;transition:background .15s}.settings-menu-item:hover{background:#00d4ff1a;color:var(--cyan)}.main-content{flex:1;max-width:1400px;margin:0 auto;width:100%;padding:1.5rem;animation:page-in .22s ease-out}@media (max-width: 640px){.main-content{padding:1rem .75rem;padding-bottom:calc(1rem + env(safe-area-inset-bottom))}.header-content,.nav-content{padding:0 .75rem}.header-brand h1{font-size:1.0625rem}.header-brand p{display:none}.header-kpi-label{font-size:.625rem}.header-kpi-value{font-size:1.125rem}.header-kpi-sub{font-size:.6875rem}}@keyframes page-in{0%{opacity:0;transform:translateY(4px)}to{opacity:1;transform:translateY(0)}}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1.5rem}.page-title{font-size:1.25rem;font-weight:600}.dashboard-grid{display:grid;gap:.75rem;margin-bottom:1.5rem}.dashboard-grid>*{min-width:0}.dashboard-grid-4{grid-template-columns:repeat(7,1fr)}.dashboard-grid-3{grid-template-columns:repeat(3,1fr)}.dashboard-grid-2{grid-template-columns:repeat(2,1fr)}@media (max-width: 1280px){.dashboard-grid-4{grid-template-columns:repeat(4,1fr)}}@media (max-width: 1024px){.dashboard-grid-4,.dashboard-grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.dashboard-grid-4{grid-template-columns:repeat(4,1fr)}.dashboard-grid-4.is-3up-mobile{grid-template-columns:repeat(3,1fr)}.dashboard-grid-3{grid-template-columns:1fr}.dashboard-grid-3.is-kpi{grid-template-columns:repeat(3,1fr);gap:.5rem}.dashboard-grid-2{grid-template-columns:1fr}.nav-content{flex-direction:column;gap:.75rem;padding:.75rem 1rem}.nav-tabs{overflow-x:auto;width:100%;padding-bottom:.25rem}.nav-actions{width:100%;justify-content:center;flex-wrap:wrap;gap:.4rem}}.chart-container{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;margin-bottom:1rem;box-shadow:var(--shadow-md);transition:border-color .2s,box-shadow .2s;min-width:0;overflow:hidden}@media (max-width: 640px){.chart-container{padding:.85rem}}.chart-container:hover{border-color:var(--border-strong)}.chart-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem}.chart-title{font-size:.9375rem;font-weight:600}.chart-wrapper{position:relative;height:300px}.stat-tile{text-align:center;padding:20px 8px;border-radius:12px;display:flex;flex-direction:column;justify-content:center;min-height:90px}.stat-tile-value{font-weight:700}.stat-tile-label{font-size:.75rem;color:var(--text-muted);margin-top:6px}@media (max-width: 640px){.stat-tile{padding:12px 4px;min-height:68px;border-radius:10px}.stat-tile-value{font-size:1.2rem!important}.stat-tile-label{font-size:.65rem;margin-top:4px}}.donut-layout{display:flex;flex-direction:row-reverse;gap:1rem;align-items:center}.donut-canvas{width:160px;height:160px;flex-shrink:0}.donut-legend{flex:1;max-height:200px;overflow-y:auto;min-width:0}@media (min-width: 641px){.donut-layout--tall .donut-legend{max-height:240px}}.range-select{display:none}@media (max-width: 640px){.donut-canvas{width:120px;height:120px}.donut-legend{max-height:180px}.range-pills{display:none!important}.range-select{display:block}}.summary-card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:.75rem;position:relative;overflow:hidden;box-shadow:var(--shadow-sm);transition:transform .18s ease,box-shadow .18s ease,border-color .18s}.summary-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);border-color:var(--border-strong)}.summary-card:before{content:"";position:absolute;left:0;top:0;bottom:0;width:3px}.summary-card.cyan:before{background:var(--cyan)}.summary-card.green:before{background:var(--green)}.summary-card.gold:before{background:var(--gold)}.summary-card.purple:before{background:var(--purple)}.summary-card.red:before{background:var(--red)}.summary-card.orange:before{background:var(--orange)}.summary-card.blue:before{background:#60a5fa}.summary-card-label{font-size:.6875rem;text-transform:uppercase;color:var(--text-muted);letter-spacing:.05em;margin-bottom:.25rem}.summary-card-value{font-size:1.5rem;font-weight:700;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.summary-card-sub{font-size:.75rem;color:var(--text-muted)}.metric-card{background:var(--bg-card);border:1px solid var(--border);border-radius:12px;padding:1.25rem;min-width:0}.metric-card-label{color:var(--text-muted);font-size:.75rem;font-weight:500;text-transform:uppercase;letter-spacing:.5px;margin-bottom:.5rem}.metric-card-value{font-size:1.75rem;font-weight:700;line-height:1.1;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;color:var(--text)}.metric-card-sub{font-size:.75rem;margin-top:.25rem;color:var(--text-muted)}@media (max-width: 640px){.summary-card{padding:.5rem .55rem;border-radius:.55rem;line-height:1.1}.summary-card:before{width:2px}.summary-card-label{font-size:.625rem;margin-bottom:.1rem;letter-spacing:.04em}.summary-card-value{font-size:1.05rem;line-height:1.15}.summary-card-sub{font-size:.625rem;line-height:1.15;margin-top:.1rem}.dashboard-grid{gap:.45rem}.metric-card{padding:.75rem .8rem;border-radius:10px}.metric-card-label{font-size:.625rem;margin-bottom:.25rem}.metric-card-value{font-size:1.25rem}.metric-card-sub{font-size:.65rem}}.data-table-container{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;overflow:hidden;box-shadow:var(--shadow-md)}.data-table-header{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:.5rem;padding:1rem 1.25rem;border-bottom:1px solid var(--border)}.data-table-title{font-size:.9375rem;font-weight:600}.data-table-badge{font-size:.6875rem;padding:.25rem .625rem;background:var(--bg-light);border-radius:9999px;color:var(--text-muted)}.data-table-wrapper{overflow-x:auto;-webkit-overflow-scrolling:touch;background:linear-gradient(to right,var(--bg-card),var(--bg-card)) left center / 24px 100% no-repeat,linear-gradient(to right,rgba(19,42,71,0),var(--bg-card)) right center / 24px 100% no-repeat,linear-gradient(to right,#00000040,#0000) left center / 12px 100% no-repeat,linear-gradient(to left,#00000040,#0000) right center / 12px 100% no-repeat;background-attachment:local,local,scroll,scroll}.data-table-wrapper::-webkit-scrollbar{height:8px}.data-table-wrapper::-webkit-scrollbar-thumb{background:var(--border-strong);border-radius:4px}.data-table-wrapper::-webkit-scrollbar-track{background:transparent}.data-table{width:100%;min-width:800px}.data-table th{cursor:pointer;-webkit-user-select:none;user-select:none}.data-table th:hover{color:var(--text)}.table-actions{display:flex;gap:.5rem;justify-content:center}.data-table th.num,.data-table td.num{text-align:right;font-variant-numeric:tabular-nums}.data-table th.center,.data-table td.center{text-align:center}.broker-badge{display:inline-block;padding:3px 10px;border-radius:6px;font-size:.7rem;font-weight:700;letter-spacing:.04em;text-transform:uppercase;border:1px solid transparent;line-height:1.4;white-space:nowrap}.broker-badge.ibkr{background:#ff3d5a1f;color:#ff7d90;border-color:#ff3d5a59}.broker-badge.t212{background:#3b82f624;color:#7eb6ff;border-color:#3b82f661}.broker-badge.default{background:#ffffff0a;color:var(--text-muted);border-color:var(--border)}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000b3;-webkit-backdrop-filter:blur(2px);backdrop-filter:blur(2px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal{background:var(--bg-card);border:1px solid var(--border-strong);border-radius:.75rem;width:100%;max-width:480px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:modal-in .18s ease-out}@keyframes modal-in{0%{opacity:0;transform:translateY(8px) scale(.98)}to{opacity:1;transform:translateY(0) scale(1)}}.modal-overlay{animation:overlay-in .18s ease-out}@keyframes overlay-in{0%{opacity:0}to{opacity:1}}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1.25rem;border-bottom:1px solid var(--border)}.modal-title{font-size:1rem;font-weight:600}.modal-close{font-size:1.5rem;color:var(--text-muted);line-height:1}.modal-close:hover{color:var(--text)}.modal-body{padding:1.25rem}.modal-footer{display:flex;justify-content:flex-end;gap:.75rem;padding:1rem 1.25rem;border-top:1px solid var(--border)}.calc-chart-wrapper{height:300px}.calc-kpi{background:var(--bg-light);border:1px solid var(--border);border-radius:.5rem;padding:.75rem;min-width:0}.calc-kpi-hl{background:#00d4ff14;border-color:var(--cyan)}.calc-kpi-label{color:var(--text-muted);font-size:.7rem;margin-bottom:.25rem}.calc-kpi-value{font-size:1.05rem;font-weight:600;white-space:nowrap;overflow:hidden;text-overflow:ellipsis}@media (max-width: 640px){.calc-modal .modal-body{padding:1rem}.calc-modal .modal-footer{padding:.75rem 1rem}.calc-modal .modal-footer .btn{width:100%}.calc-chart-wrapper{height:220px}.calc-kpi{padding:.5rem .6rem}.calc-kpi-label{font-size:.625rem}.calc-kpi-value{font-size:.95rem}}.form-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:1rem}@media (max-width: 640px){.form-grid{grid-template-columns:1fr}}.empty-state{text-align:center;padding:3rem;color:var(--text-muted)}.empty-state-icon{font-size:3rem;margin-bottom:1rem;opacity:.5}.error-state{text-align:center;padding:3rem;color:var(--red)}:root{--bg: #0c1c30;--bg-light: #112640;--bg-card: #132a47;--bg-card-hover: #17325a;--cyan: #00d4ff;--green: #00e5a0;--gold: #ffc940;--orange: #fb923c;--purple: #c084fc;--red: #ff3d5a;--text: #dff0ff;--text-muted: #7a99b8;--border: rgba(0, 212, 255, .18);--border-strong: rgba(0, 212, 255, .28);--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 2px 10px rgba(0, 0, 0, .35);--shadow-lg: 0 10px 30px rgba(0, 0, 0, .45)}*{box-sizing:border-box;margin:0;padding:0}html{font-size:clamp(14px,.85vw + 12px,15px)}body{font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;background:var(--bg);color:var(--text);line-height:1.5;min-height:100vh;overflow-x:hidden;-webkit-text-size-adjust:100%}img,svg,video,canvas{max-width:100%;height:auto}@media (pointer: coarse){button,.btn,a.btn{min-height:44px}}.responsive-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(var(--col-min, 220px),1fr));gap:1rem}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.2}.mono{font-family:Space Mono,monospace}a{color:var(--cyan);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;background:none}.btn{display:inline-flex;align-items:center;gap:.5rem;padding:.625rem 1.25rem;border-radius:.5rem;font-weight:500;font-size:.875rem;transition:all .2s}.btn-primary{background:var(--cyan);color:var(--bg)}.btn-primary:hover{background:#00b8e6}.btn-secondary{background:var(--bg-card);color:var(--text);border:1px solid var(--border);box-shadow:var(--shadow-sm)}.btn-secondary:hover{background:var(--bg-card-hover);border-color:var(--border-strong)}.btn-danger{background:transparent;color:#ff7d90;border:1px solid rgba(255,61,90,.35);transition:background .15s,color .15s,border-color .15s}.btn-danger:hover{background:#ff3d5ae6;color:#fff;border-color:#ff3d5ae6}.btn-danger:active{background:#e62846}.btn-sm{padding:.375rem .75rem;font-size:.75rem}input,select,textarea{font-family:inherit;font-size:.875rem;padding:.625rem .875rem;border:1px solid var(--border);border-radius:.5rem;background:var(--bg-light);color:var(--text);width:100%;transition:border-color .2s}input:focus,select:focus,textarea:focus{outline:none;border-color:var(--cyan)}input::placeholder{color:var(--text-muted)}label{display:block;font-size:.75rem;font-weight:500;color:var(--text-muted);margin-bottom:.375rem;text-transform:uppercase;letter-spacing:.05em}table{width:100%;border-collapse:collapse;font-size:.8125rem}th,td{padding:.75rem 1rem;text-align:left;border-bottom:1px solid var(--border)}th{font-weight:600;color:var(--text-muted);text-transform:uppercase;font-size:.75rem;letter-spacing:.05em;background:#ffffff05}tbody tr:nth-child(2n) td{background:#ffffff05}tbody tr:hover td{background:#00d4ff0f}.card{background:var(--bg-card);border:1px solid var(--border);border-radius:.75rem;padding:1.25rem;box-shadow:var(--shadow-md)}.card-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:1rem;padding-bottom:.75rem;border-bottom:1px solid var(--border)}.card-title{font-size:.875rem;font-weight:600;color:var(--text)}.container{max-width:1400px;margin:0 auto;padding:0 1.5rem}.grid{display:grid;gap:1rem}.grid-2{grid-template-columns:repeat(2,1fr)}.grid-3{grid-template-columns:repeat(3,1fr)}.grid-4{grid-template-columns:repeat(4,1fr)}@media (max-width: 1024px){.grid-4,.grid-3{grid-template-columns:repeat(2,1fr)}}@media (max-width: 640px){.grid-4,.grid-3,.grid-2{grid-template-columns:1fr}}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-between{justify-content:space-between}.gap-2{gap:.5rem}.gap-4{gap:1rem}.text-cyan{color:var(--cyan)}.text-green{color:var(--green)}.text-red{color:var(--red)}.text-gold{color:var(--gold)}.text-muted{color:var(--text-muted)}.text-right{text-align:right}.text-center{text-align:center}.text-xs{font-size:.75rem}.text-sm{font-size:.875rem}.text-lg{font-size:1.125rem}.text-xl{font-size:1.25rem}.font-mono{font-family:Space Mono,monospace}.font-semibold{font-weight:600}.font-bold{font-weight:700}.pos{color:var(--green)}.neg{color:var(--red)}.loading{opacity:.6;pointer-events:none}::-webkit-scrollbar{width:8px;height:8px}::-webkit-scrollbar-track{background:var(--bg-light);border-radius:4px}::-webkit-scrollbar-thumb{background:#00d4ff2e;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#00d4ff59}
