@import "https://fonts.googleapis.com/css2?family=Inter:wght@300;400;500;600;700&family=Outfit:wght@400;500;600;700&display=swap";:root{--bg-primary:#0f111a;--bg-secondary:#161925;--bg-glass:#16192599;--text-primary:#e2e8f0;--text-secondary:#94a3b8;--accent:#3b82f6;--accent-glow:#3b82f680;--accent-gradient:linear-gradient(135deg, #3b82f6 0%, #8b5cf6 100%);--success:#ef4444;--danger:#10b981;--border:#ffffff14;--radius-lg:16px;--radius-md:12px;--shadow-glow:0 0 20px #3b82f626}*{box-sizing:border-box;margin:0;padding:0}body{background-color:var(--bg-primary);color:var(--text-primary);-webkit-font-smoothing:antialiased;background-image:radial-gradient(circle at 15%,#3b82f60d,#0000 25%),radial-gradient(circle at 85% 30%,#8b5cf60d,#0000 25%);min-height:100vh;font-family:Inter,sans-serif}h1,h2,h3,h4,h5,h6{font-family:Outfit,sans-serif;font-weight:600}.app-container{max-width:1200px;margin:0 auto;padding:2rem}.nav-tabs{gap:1rem;margin-top:1rem;display:flex}.nav-tab{color:var(--text-secondary);cursor:pointer;background:0 0;border:none;border-bottom:2px solid #0000;padding:.5rem 1rem;font-size:1rem;font-weight:500;transition:all .2s}.nav-tab:hover{color:var(--text-primary)}.nav-tab.active{color:var(--accent);border-bottom-color:var(--accent)}.header{justify-content:space-between;align-items:center;margin-bottom:2rem;display:flex}.header-title{background:var(--accent-gradient);-webkit-text-fill-color:transparent;-webkit-background-clip:text;font-size:2rem;display:inline-block}.header-subtitle{color:var(--text-secondary);margin-top:.25rem;font-size:.95rem}.glass-card{background:var(--bg-glass);-webkit-backdrop-filter:blur(12px);border:1px solid var(--border);border-radius:var(--radius-lg);padding:1.5rem;transition:transform .2s,box-shadow .2s;box-shadow:0 4px 6px -1px #0000001a,0 2px 4px -1px #0000000f}.glass-card:hover{box-shadow:var(--shadow-glow);transform:translateY(-2px)}.dashboard-grid{grid-template-columns:repeat(12,1fr);gap:1.5rem;display:grid}.kpi-row{grid-column:span 12;grid-template-columns:repeat(auto-fit,minmax(240px,1fr));gap:1.5rem;display:grid}.chart-section{grid-column:span 8}.allocation-section{grid-column:span 4}.chart-body{width:100%;min-width:0;height:320px;min-height:0}.portfolio-table-section{grid-column:span 12;overflow-x:auto}@media (width<=1024px){.chart-section,.allocation-section{grid-column:span 12}}.text-success{color:var(--success)}.text-danger{color:var(--danger)}.text-secondary{color:var(--text-secondary)}.badge{border-radius:4px;padding:.25rem .5rem;font-size:.8rem;font-weight:500;display:inline-block}.badge-buy{color:var(--success);background-color:#ef444426}.badge-sell{color:var(--danger);background-color:#10b98126}.kpi-card{flex-direction:column;gap:.5rem;display:flex}.kpi-label{color:var(--text-secondary);align-items:center;gap:.5rem;font-size:.9rem;font-weight:500;display:flex}.kpi-value{font-family:Outfit,sans-serif;font-size:2rem;font-weight:700}.kpi-trend{align-items:center;gap:.25rem;font-size:.85rem;display:flex}.card-title{align-items:center;gap:.5rem;margin-bottom:1.5rem;font-size:1.2rem;display:flex}.data-table{border-collapse:collapse;width:100%}.data-table th,.data-table td{text-align:right;border-bottom:1px solid var(--border);vertical-align:top;padding:1rem}.data-table th.sortable-header{cursor:pointer;-webkit-user-select:none;user-select:none;transition:color .2s}.data-table th.sortable-header:hover{color:var(--primary)}.sort-icon{vertical-align:middle;margin-left:4px;display:inline-block}.sort-icon-placeholder{width:18px;display:inline-block}.data-table th:first-child,.data-table td:first-child{text-align:left}.data-table th{color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em;font-size:.85rem;font-weight:500}.data-table tbody tr{transition:background-color .15s}.data-table tbody tr:hover{background-color:#ffffff05}@keyframes fadeIn{0%{opacity:0;transform:translateY(10px)}to{opacity:1;transform:translateY(0)}}.animate-fade-in{animation:.5s ease-out forwards fadeIn}.delay-1{opacity:0;animation-delay:.1s}.delay-2{opacity:0;animation-delay:.2s}.delay-3{opacity:0;animation-delay:.3s}.loader-container{flex-direction:column;justify-content:center;align-items:center;gap:1rem;height:50vh;display:flex}.loader{border:3px solid var(--border);border-top-color:var(--accent);border-radius:50%;width:40px;height:40px;animation:1s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}.spin{animation:1s linear infinite spin}
