*,*:before,*:after{margin:0;padding:0;box-sizing:border-box}html{font-size:16px;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale}body{font-family:var(--font-family);background-color:var(--color-bg-primary);color:var(--color-text-primary);line-height:1.6;min-height:100vh}a{color:var(--color-accent);text-decoration:none}a:hover{text-decoration:underline}button{font-family:inherit;cursor:pointer;border:none;outline:none}input,textarea,select{font-family:inherit;font-size:inherit;outline:none}table{border-collapse:collapse;width:100%}img{max-width:100%;display:block}ul,ol{list-style:none}h1,h2,h3,h4,h5,h6{font-weight:600;line-height:1.3}::-webkit-scrollbar{width:8px}::-webkit-scrollbar-track{background:var(--color-bg-primary)}::-webkit-scrollbar-thumb{background:var(--color-border);border-radius:4px}::-webkit-scrollbar-thumb:hover{background:var(--color-text-muted)}:root{--color-bg-primary: #0f1923;--color-bg-secondary: #1a2733;--color-bg-card: #1e2d3d;--color-bg-hover: #253545;--color-bg-input: #162230;--color-border: #2a3a4a;--color-text-primary: #e8edf2;--color-text-secondary: #8899aa;--color-text-muted: #5a6a7a;--color-accent: #4a9eff;--color-accent-hover: #3a8eef;--color-success: #34d399;--color-warning: #fbbf24;--color-danger: #f87171;--color-danger-hover: #ef4444;--color-equity: #4a9eff;--color-bonds: #a78bfa;--color-insurance: #34d399;--color-mutual-funds: #fbbf24;--color-gold: #f59e0b;--color-real-estate: #f87171;--space-xs: 4px;--space-sm: 8px;--space-md: 16px;--space-lg: 24px;--space-xl: 32px;--space-2xl: 48px;--font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", sans-serif;--font-size-xs: .75rem;--font-size-sm: .875rem;--font-size-base: 1rem;--font-size-lg: 1.125rem;--font-size-xl: 1.25rem;--font-size-2xl: 1.5rem;--font-size-3xl: 2rem;--radius-sm: 6px;--radius-md: 8px;--radius-lg: 12px;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .3);--shadow-md: 0 4px 6px rgba(0, 0, 0, .3);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .4);--sidebar-width: 260px;--header-height: 56px;--mobile-nav-height: 60px}[data-theme=light]{--color-bg-primary: #f5f7fa;--color-bg-secondary: #ffffff;--color-bg-card: #ffffff;--color-bg-hover: #f0f2f5;--color-bg-input: #f8f9fb;--color-border: #e2e8f0;--color-text-primary: #1a202c;--color-text-secondary: #4a5568;--color-text-muted: #a0aec0;--shadow-sm: 0 1px 2px rgba(0, 0, 0, .05);--shadow-md: 0 4px 6px rgba(0, 0, 0, .07);--shadow-lg: 0 10px 25px rgba(0, 0, 0, .1)}.flex{display:flex}.flex-col{flex-direction:column}.items-center{align-items:center}.justify-center{justify-content:center}.justify-between{justify-content:space-between}.gap-xs{gap:var(--space-xs)}.gap-sm{gap:var(--space-sm)}.gap-md{gap:var(--space-md)}.gap-lg{gap:var(--space-lg)}.gap-xl{gap:var(--space-xl)}.text-center{text-align:center}.text-sm{font-size:var(--font-size-sm)}.text-muted{color:var(--color-text-secondary)}.w-full{width:100%}.btn{display:inline-flex;align-items:center;justify-content:center;gap:var(--space-sm);padding:10px 20px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;transition:all .2s ease;border:none;cursor:pointer}.btn-primary{background:var(--color-accent);color:#fff}.btn-primary:hover{background:var(--color-accent-hover)}.btn-danger{background:var(--color-danger);color:#fff}.btn-danger:hover{background:var(--color-danger-hover)}.btn-outline{background:transparent;color:var(--color-text-primary);border:1px solid var(--color-border)}.btn-outline:hover{background:var(--color-bg-hover)}.btn-sm{padding:6px 12px;font-size:var(--font-size-xs)}.btn-icon{padding:8px;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-sm)}.btn-icon:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.card{background:var(--color-bg-card);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-lg);box-shadow:var(--shadow-sm)}.page-title{font-size:var(--font-size-2xl);font-weight:700;margin-bottom:var(--space-lg)}.section-title{font-size:var(--font-size-lg);font-weight:600;margin-bottom:var(--space-md);color:var(--color-text-primary)}.error-text{color:var(--color-danger);font-size:var(--font-size-sm)}.success-text{color:var(--color-success);font-size:var(--font-size-sm)}.spinner-overlay{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--color-bg-primary)}.spinner{width:40px;height:40px;border:3px solid var(--color-border);border-top-color:var(--color-accent);border-radius:50%;animation:spin .8s linear infinite}@keyframes spin{to{transform:rotate(360deg)}}.sidebar{background:var(--color-bg-secondary);border-right:1px solid var(--color-border);display:flex;flex-direction:column;height:100vh;position:sticky;top:0}.sidebar-brand{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.sidebar-logo-img{height:36px;width:auto;object-fit:contain}.sidebar-logo-light{display:none}.sidebar-logo-dark,[data-theme=light] .sidebar-logo-light{display:block}[data-theme=light] .sidebar-logo-dark{display:none}.sidebar-nav{flex:1;padding:var(--space-md);display:flex;flex-direction:column;gap:var(--space-xs)}.sidebar-link{display:flex;align-items:center;gap:var(--space-sm);padding:12px 16px;border-radius:var(--radius-md);color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;transition:all .2s;text-decoration:none}.sidebar-link:hover{background:var(--color-bg-hover);color:var(--color-text-primary);text-decoration:none}.sidebar-link--active{background:#4a9eff1a;color:var(--color-accent)}.sidebar-link--active:hover{background:#4a9eff26}.sidebar-icon{font-size:var(--font-size-lg);width:24px;text-align:center}.sidebar-footer{padding:var(--space-md) var(--space-lg);border-top:1px solid var(--color-border);font-size:var(--font-size-xs);color:var(--color-text-muted)}.sidebar-version{margin-top:2px;opacity:.7}@media(max-width:768px){.sidebar{display:none}}.mobile-bottom-nav{display:none}@media(max-width:768px){.mobile-bottom-nav{display:flex;position:fixed;bottom:0;left:0;right:0;height:var(--mobile-nav-height);background:var(--color-bg-secondary);border-top:1px solid var(--color-border);z-index:200;padding-bottom:env(safe-area-inset-bottom,0px)}.mobile-nav-item{flex:1;display:flex;flex-direction:column;align-items:center;justify-content:center;gap:3px;color:var(--color-text-muted);text-decoration:none;font-size:var(--font-size-xs);font-weight:500;transition:color .2s;padding:6px 0}.mobile-nav-item--active{color:var(--color-accent)}.mobile-nav-icon{font-size:20px;line-height:1}.mobile-nav-label{font-size:10px;letter-spacing:.2px}}.header{height:var(--header-height);background:var(--color-bg-secondary);border-bottom:1px solid var(--color-border);display:flex;align-items:center;justify-content:space-between;padding:0 var(--space-lg);position:sticky;top:0;z-index:100}.header-greeting{font-size:var(--font-size-lg);font-weight:600}.header-right{display:flex;align-items:center;gap:var(--space-md)}.header-theme-btn{width:36px;height:36px;display:flex;align-items:center;justify-content:center;background:var(--color-bg-hover);border-radius:var(--radius-md);font-size:var(--font-size-lg);transition:background .2s}.header-theme-btn:hover{background:var(--color-border)}.header-user{display:flex;align-items:center;gap:var(--space-sm)}.header-avatar{width:32px;height:32px;background:var(--color-accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-weight:600;font-size:var(--font-size-sm)}.header-email{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.header-brand-mobile{display:none}@media(max-width:768px){.header{padding:0 var(--space-sm);gap:var(--space-sm)}.header-left{display:flex;align-items:center;gap:var(--space-sm);min-width:0}.header-brand-mobile{display:flex;align-items:center;justify-content:center;width:30px;height:30px;background:var(--color-accent);color:#fff;border-radius:var(--radius-md);font-weight:700;font-size:var(--font-size-xs);flex-shrink:0}.header-greeting{font-size:var(--font-size-sm);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.header-right{gap:var(--space-sm)}.header-email,.header-logout{display:none}}.dashboard-layout{display:grid;grid-template-columns:var(--sidebar-width) 1fr;min-height:100vh}.dashboard-main{display:flex;flex-direction:column;min-height:100vh;overflow:hidden}.dashboard-content{flex:1;padding:var(--space-lg);overflow-y:auto;background:var(--color-bg-primary)}@media(max-width:768px){.dashboard-layout{grid-template-columns:1fr}.dashboard-content{padding:var(--space-md) var(--space-sm);padding-bottom:calc(var(--mobile-nav-height) + var(--space-md))}}.auth-page{min-height:100vh;display:flex;align-items:center;justify-content:center;padding:var(--space-md);background:linear-gradient(135deg,#0a1628,#1a2733,#0f1923)}.auth-card{width:100%;max-width:420px;background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);padding:var(--space-2xl);box-shadow:var(--shadow-lg)}.auth-header{text-align:center;margin-bottom:var(--space-xl)}.auth-brand-logo{height:80px;width:auto;margin-bottom:var(--space-xs)}.auth-brand-logo--light{display:none}.auth-brand-logo--dark,[data-theme=light] .auth-brand-logo--light{display:block}[data-theme=light] .auth-brand-logo--dark{display:none}.auth-subtitle{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.auth-error{background:#f871711a;border:1px solid rgba(248,113,113,.3);color:var(--color-danger);padding:12px 16px;border-radius:var(--radius-md);font-size:var(--font-size-sm);margin-bottom:var(--space-md)}.auth-form{display:flex;flex-direction:column;gap:var(--space-md)}.auth-field{display:flex;flex-direction:column;gap:6px}.auth-field label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.auth-field input{width:100%;padding:12px 16px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-base);transition:border-color .2s,box-shadow .2s}.auth-field input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #4a9eff26}.auth-field input::placeholder{color:var(--color-text-muted)}.auth-submit{width:100%;padding:12px;background:var(--color-accent);color:#fff;border:none;border-radius:var(--radius-md);font-size:var(--font-size-base);font-weight:600;cursor:pointer;transition:background .2s;margin-top:var(--space-sm)}.auth-submit:hover:not(:disabled){background:var(--color-accent-hover)}.auth-submit:disabled{opacity:.6;cursor:not-allowed}.auth-footer{text-align:center;margin-top:var(--space-lg);font-size:var(--font-size-sm);color:var(--color-text-secondary)}.auth-footer a{color:var(--color-accent);font-weight:500}.auth-footer a:hover{text-decoration:underline}.asset-card{background:var(--color-bg-card);border:1px solid var(--color-border);border-top:3px solid var(--color-accent);border-radius:var(--radius-lg);padding:var(--space-lg);cursor:pointer;transition:all .2s;box-shadow:var(--shadow-sm)}.asset-card:hover{transform:translateY(-2px);box-shadow:var(--shadow-md);background:var(--color-bg-hover)}.asset-card-header{display:flex;align-items:center;gap:var(--space-sm);margin-bottom:var(--space-md)}.asset-card-icon{font-size:var(--font-size-2xl)}.asset-card-label{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px}.asset-card-live-badge{margin-left:auto;font-size:10px;font-weight:700;color:var(--color-success);background:#34d3991a;border:1px solid rgba(52,211,153,.3);padding:2px 8px;border-radius:10px;letter-spacing:1px}.asset-card-value{font-size:var(--font-size-2xl);font-weight:700;color:var(--color-text-primary);margin-bottom:var(--space-xs)}.asset-card-change{font-size:var(--font-size-sm);font-weight:500;margin-bottom:var(--space-xs)}.asset-card-change.price-up{color:var(--color-success)}.asset-card-change.price-down{color:var(--color-danger)}.asset-card-count{font-size:var(--font-size-sm);color:var(--color-text-muted)}.portfolio-charts{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md);margin-bottom:var(--space-xl)}.chart-card{padding:var(--space-lg)}.chart-title{font-size:var(--font-size-base);font-weight:600;color:var(--color-text-secondary);text-transform:uppercase;letter-spacing:.5px;margin:0 0 var(--space-md) 0}.allocation-content{display:flex;align-items:center;gap:var(--space-lg)}.donut-svg{flex-shrink:0}.donut-segment{transition:opacity .2s}.donut-center-num{font-size:22px;font-weight:700;fill:var(--color-text-primary)}.donut-center-label{font-size:10px;fill:var(--color-text-muted)}.allocation-legend{flex:1;display:flex;flex-direction:column;gap:var(--space-sm)}.legend-item{display:grid;grid-template-columns:10px 1fr auto auto;align-items:center;gap:var(--space-sm)}.legend-dot{width:10px;height:10px;border-radius:50%;flex-shrink:0}.legend-name{font-size:var(--font-size-sm);color:var(--color-text-primary);white-space:nowrap}.legend-pct{font-size:var(--font-size-sm);font-weight:600;color:var(--color-text-secondary);text-align:right;min-width:40px}.legend-val{font-size:var(--font-size-xs);color:var(--color-text-muted);text-align:right;min-width:70px}.returns-overall{display:flex;align-items:center;gap:var(--space-sm);padding:var(--space-sm) var(--space-md);background:var(--color-bg-secondary);border-radius:var(--radius-md);margin-bottom:var(--space-md)}.returns-overall-label{font-size:var(--font-size-sm);color:var(--color-text-muted);margin-right:auto}.returns-overall-val{font-size:var(--font-size-base);font-weight:700}.returns-overall-pct{font-size:var(--font-size-sm);font-weight:600}.returns-list{display:flex;flex-direction:column;gap:var(--space-md)}.returns-item{display:flex;flex-direction:column;gap:4px}.returns-item-header{display:flex;align-items:center;justify-content:space-between}.returns-cat-name{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-primary)}.returns-cat-dot{width:8px;height:8px;border-radius:50%;flex-shrink:0}.returns-pnl{font-size:var(--font-size-sm);font-weight:600}.returns-bar-track{height:6px;background:var(--color-border);border-radius:3px;overflow:hidden}.returns-bar-fill{height:100%;border-radius:3px;transition:width .6s ease}.returns-item-footer{display:flex;justify-content:space-between;font-size:var(--font-size-xs);color:var(--color-text-muted)}.returns-empty{color:var(--color-text-muted);font-size:var(--font-size-sm);text-align:center;padding:var(--space-lg) 0}@media(max-width:900px){.portfolio-charts{grid-template-columns:1fr}}@media(max-width:480px){.allocation-content{flex-direction:column;align-items:flex-start}.donut-svg{align-self:center}}.overview-page{max-width:1200px}.overview-title-row{display:flex;align-items:center;justify-content:space-between;flex-wrap:wrap;gap:var(--space-sm)}.overview-price-status{display:flex;align-items:center;gap:var(--space-xs);font-size:var(--font-size-xs);color:var(--color-text-muted)}.live-dot-sm{width:6px;height:6px;background:var(--color-success);border-radius:50%;animation:pulse 2s infinite}.overview-summary{margin-bottom:var(--space-xl);text-align:center;padding:var(--space-xl)}.overview-summary-label{font-size:var(--font-size-sm);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:1px;margin-bottom:var(--space-sm)}.overview-summary-value{font-size:var(--font-size-3xl);font-weight:700;color:var(--color-accent);margin-bottom:var(--space-xs)}.overview-summary-count{font-size:var(--font-size-sm);color:var(--color-text-secondary)}.overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(280px,1fr));gap:var(--space-md)}.overview-loading{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--color-text-secondary);font-size:var(--font-size-lg)}@media(max-width:768px){.overview-page{max-width:100%}.overview-summary{padding:var(--space-md);margin-bottom:var(--space-md)}.overview-summary-value{font-size:var(--font-size-2xl)}.overview-grid{grid-template-columns:1fr 1fr;gap:var(--space-sm)}}@media(max-width:400px){.overview-grid{grid-template-columns:1fr}}.stock-detail{padding:var(--space-md) var(--space-lg);background:var(--color-bg-primary);border-top:1px solid var(--color-border);animation:detailSlide .2s ease}.stock-detail-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(140px,1fr));gap:var(--space-md)}.stock-detail-item{display:flex;flex-direction:column;gap:4px}.stock-detail-label{font-size:var(--font-size-xs);color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;font-weight:600}.stock-detail-value{font-size:var(--font-size-sm);color:var(--color-text-primary);font-weight:500}.stock-detail-row td{padding:0!important;border-bottom:2px solid var(--color-accent)!important}.equity-row{transition:background .15s}.equity-row:hover,.equity-row--expanded{background:var(--color-bg-hover)}@keyframes detailSlide{0%{opacity:0}to{opacity:1}}@media(max-width:560px){.stock-detail-grid{grid-template-columns:repeat(2,1fr)}}.asset-table-wrapper{overflow-x:auto;border:1px solid var(--color-border);border-radius:var(--radius-lg)}.asset-table{width:100%;border-collapse:collapse}.asset-table thead{background:var(--color-bg-secondary)}.asset-table th{padding:14px 16px;text-align:left;font-size:var(--font-size-xs);font-weight:600;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px;border-bottom:1px solid var(--color-border);white-space:nowrap}.asset-table td{padding:14px 16px;font-size:var(--font-size-sm);color:var(--color-text-primary);border-bottom:1px solid var(--color-border)}.asset-table tbody tr:hover{background:var(--color-bg-hover)}.asset-table tbody tr:last-child td{border-bottom:none}.asset-table-name{font-weight:500}.asset-table-ticker{font-family:Courier New,monospace;font-size:var(--font-size-xs);color:var(--color-text-secondary)}.asset-table-actions{display:flex;gap:var(--space-sm)}.asset-table-live-price .live-price{font-weight:600;color:var(--color-accent)}.live-price-loading{color:var(--color-text-muted);font-size:var(--font-size-xs);font-style:italic}.price-change{display:flex;flex-direction:column;gap:2px}.price-change-value{font-weight:500;font-size:var(--font-size-sm)}.price-change-percent{font-size:var(--font-size-xs)}.price-up{color:var(--color-success)}.price-down{color:var(--color-danger)}.asset-table-empty{text-align:center;padding:var(--space-2xl);color:var(--color-text-secondary);background:var(--color-bg-card);border:1px dashed var(--color-border);border-radius:var(--radius-lg)}.asset-table-empty p:first-child{font-size:var(--font-size-lg);margin-bottom:var(--space-sm)}.asset-table--equity th,.asset-table--equity td{text-align:right}.asset-table--equity th:first-child,.asset-table--equity td:first-child{text-align:left}.asset-table--equity th:last-child,.asset-table--equity td:last-child{text-align:center}.asset-table-ticker-cell{display:flex;flex-direction:column;gap:2px}.ticker-symbol{font-weight:700;font-size:var(--font-size-sm);color:var(--color-text-primary);letter-spacing:.3px}.ticker-exchange{font-size:10px;color:var(--color-text-muted);text-transform:uppercase;letter-spacing:.5px}.return-badge{display:inline-block;padding:2px 10px;border-radius:12px;font-size:var(--font-size-xs);font-weight:600;white-space:nowrap}.return-up{background:#10b9811f;color:var(--color-success)}.return-down{background:#ef44441f;color:var(--color-danger)}@media(max-width:768px){.asset-table th,.asset-table td{padding:10px 8px;font-size:var(--font-size-xs)}.asset-table--equity th:nth-child(2),.asset-table--equity td:nth-child(2),.asset-table--equity th:nth-child(3),.asset-table--equity td:nth-child(3),.asset-table--equity th:nth-child(4),.asset-table--equity td:nth-child(4),.asset-table--equity th:nth-child(6),.asset-table--equity td:nth-child(6),.asset-table--equity th:nth-child(7),.asset-table--equity td:nth-child(7){display:none}.asset-table:not(.asset-table--equity) th:nth-child(6),.asset-table:not(.asset-table--equity) td:nth-child(6),.asset-table:not(.asset-table--equity) th:nth-child(7),.asset-table:not(.asset-table--equity) td:nth-child(7),.asset-table:not(.asset-table--equity) th:nth-child(8),.asset-table:not(.asset-table--equity) td:nth-child(8){display:none}.asset-table-actions{flex-direction:column;gap:4px}.asset-table-actions .btn{font-size:10px;padding:4px 8px}.return-badge{padding:2px 6px}}.form-field{display:flex;flex-direction:column;gap:6px}.form-label{font-size:var(--font-size-sm);font-weight:500;color:var(--color-text-secondary)}.form-required{color:var(--color-danger);margin-left:2px}.form-input{width:100%;padding:10px 14px;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-md);color:var(--color-text-primary);font-size:var(--font-size-sm);transition:border-color .2s,box-shadow .2s}.form-input:focus{border-color:var(--color-accent);box-shadow:0 0 0 3px #4a9eff26}.form-input:disabled{opacity:.6;cursor:not-allowed}.form-input--error{border-color:var(--color-danger)}.form-input--error:focus{box-shadow:0 0 0 3px #f8717126}.form-textarea{resize:vertical;min-height:80px}.form-error{font-size:var(--font-size-xs);color:var(--color-danger)}select.form-input{appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%238899aa' d='M6 8L1 3h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right 12px center;padding-right:36px}.asset-form{display:flex;flex-direction:column;gap:var(--space-lg)}.asset-form-grid{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.asset-form-grid .form-field:has(textarea){grid-column:1 / -1}.asset-form-actions{display:flex;justify-content:flex-end;gap:var(--space-sm);padding-top:var(--space-md);border-top:1px solid var(--color-border)}@media(max-width:560px){.asset-form-grid{grid-template-columns:1fr}}.equity-form-fields{display:flex;flex-direction:column;gap:var(--space-md)}.equity-ticker-wrapper{display:flex;flex-direction:column}.ticker-status{display:block;font-size:var(--font-size-xs);margin-top:6px;padding:0 2px}.ticker-loading{color:var(--color-accent);font-style:italic}.ticker-success{color:var(--color-success);font-weight:500}.ticker-error{color:var(--color-danger)}.equity-row-fields{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.equity-exchange-toggle{display:flex;align-items:center;gap:var(--space-sm)}.exchange-label{font-size:var(--font-size-sm);color:var(--color-text-secondary);font-weight:500}.exchange-btn{padding:6px 16px;font-size:var(--font-size-xs);font-weight:600;background:var(--color-bg-input);border:1px solid var(--color-border);border-radius:var(--radius-sm);color:var(--color-text-secondary);cursor:pointer;transition:all .2s}.exchange-btn:hover{background:var(--color-bg-hover)}.exchange-btn--active{background:var(--color-accent);color:#fff;border-color:var(--color-accent)}@media(max-width:560px){.equity-row-fields{grid-template-columns:1fr}}.modal-overlay{position:fixed;inset:0;background:#0009;-webkit-backdrop-filter:blur(4px);backdrop-filter:blur(4px);display:flex;align-items:center;justify-content:center;z-index:1000;padding:var(--space-md);animation:fadeIn .2s ease}.modal-content{background:var(--color-bg-secondary);border:1px solid var(--color-border);border-radius:var(--radius-lg);width:100%;max-width:560px;max-height:90vh;overflow-y:auto;box-shadow:var(--shadow-lg);animation:slideUp .2s ease}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:var(--space-lg);border-bottom:1px solid var(--color-border)}.modal-header h3{font-size:var(--font-size-lg);font-weight:600}.modal-close{width:32px;height:32px;display:flex;align-items:center;justify-content:center;background:transparent;color:var(--color-text-secondary);border-radius:var(--radius-sm);font-size:var(--font-size-lg);transition:all .2s}.modal-close:hover{background:var(--color-bg-hover);color:var(--color-text-primary)}.modal-body{padding:var(--space-lg)}@keyframes fadeIn{0%{opacity:0}to{opacity:1}}@keyframes slideUp{0%{transform:translateY(20px);opacity:0}to{transform:translateY(0);opacity:1}}@media(max-width:560px){.modal-overlay{align-items:flex-end;padding:0}.modal-content{max-width:100%;max-height:92vh;border-radius:var(--radius-lg) var(--radius-lg) 0 0;animation:slideUpSheet .25s ease}.modal-header,.modal-body{padding:var(--space-md)}}@keyframes slideUpSheet{0%{transform:translateY(100%)}to{transform:translateY(0)}}.toast{position:fixed;top:20px;right:20px;display:flex;align-items:center;gap:var(--space-sm);padding:12px 20px;border-radius:var(--radius-md);font-size:var(--font-size-sm);font-weight:500;z-index:2000;animation:toastIn .3s ease;box-shadow:var(--shadow-lg)}.toast--success{background:#065f46;color:#d1fae5;border:1px solid #34d399}.toast--error{background:#7f1d1d;color:#fecaca;border:1px solid #f87171}.toast--info{background:#1e3a5f;color:#bfdbfe;border:1px solid #4a9eff}.toast-icon{font-size:var(--font-size-base);font-weight:700}.toast-message{flex:1}.toast-close{background:transparent;color:inherit;opacity:.7;font-size:var(--font-size-xs);padding:2px}.toast-close:hover{opacity:1}@keyframes toastIn{0%{transform:translate(100%);opacity:0}to{transform:translate(0);opacity:1}}.assets-page{max-width:1200px}.assets-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg);flex-wrap:wrap;gap:var(--space-md)}.assets-header-actions{display:flex;align-items:center;gap:var(--space-md)}.live-price-controls{display:flex;align-items:center;gap:var(--space-sm)}.last-updated{font-size:var(--font-size-xs);color:var(--color-text-muted)}.assets-tabs{display:flex;gap:0;border-bottom:2px solid var(--color-border);margin-bottom:var(--space-md);overflow-x:auto}.assets-tab{display:flex;align-items:center;gap:var(--space-xs);padding:12px 20px;background:transparent;color:var(--color-text-secondary);font-size:var(--font-size-sm);font-weight:500;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s;white-space:nowrap}.assets-tab:hover{color:var(--color-text-primary);background:var(--color-bg-hover)}.assets-tab--active{color:var(--color-text-primary);border-bottom-width:2px;border-bottom-style:solid}.live-price-banner{display:flex;align-items:center;gap:var(--space-sm);padding:10px 16px;background:#4a9eff14;border:1px solid rgba(74,158,255,.2);border-radius:var(--radius-md);font-size:var(--font-size-xs);color:var(--color-text-secondary);margin-bottom:var(--space-md)}.live-price-banner--gold{background:#f59e0b14;border-color:#f59e0b40}.live-dot{width:8px;height:8px;background:var(--color-success);border-radius:50%;flex-shrink:0;animation:pulse 2s infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.assets-loading{display:flex;align-items:center;justify-content:center;min-height:200px;color:var(--color-text-secondary)}@media(max-width:768px){.assets-page{max-width:100%}.assets-header{margin-bottom:var(--space-sm);gap:var(--space-sm)}.assets-header-actions{width:100%;justify-content:space-between}.live-price-controls{flex:1;flex-wrap:wrap}.assets-tab{padding:10px;font-size:var(--font-size-xs);gap:3px}.live-price-banner{font-size:11px;padding:8px 10px}}.profile-page{max-width:800px}.profile-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:var(--space-lg)}.profile-actions{display:flex;gap:var(--space-sm)}.profile-avatar-section{display:flex;align-items:center;gap:var(--space-lg);margin-bottom:var(--space-lg)}.profile-avatar{width:72px;height:72px;background:var(--color-accent);color:#fff;border-radius:50%;display:flex;align-items:center;justify-content:center;font-size:var(--font-size-3xl);font-weight:700;flex-shrink:0}.profile-name{font-size:var(--font-size-xl);font-weight:600;margin-bottom:var(--space-xs)}.profile-email{color:var(--color-text-secondary);font-size:var(--font-size-sm)}.profile-section{margin-bottom:var(--space-lg)}.profile-fields{display:grid;grid-template-columns:1fr 1fr;gap:var(--space-md)}.profile-loading{display:flex;align-items:center;justify-content:center;min-height:300px;color:var(--color-text-secondary);font-size:var(--font-size-lg)}.kyc-documents{display:flex;flex-direction:column;gap:var(--space-md)}.kyc-card{display:flex;align-items:center;gap:var(--space-md);padding:var(--space-md);border:1px solid var(--color-border);border-radius:var(--radius-md);background:var(--color-bg-secondary)}.kyc-card-icon{font-size:2rem;flex-shrink:0}.kyc-card-info{flex:1;min-width:0}.kyc-card-label{font-weight:600;font-size:var(--font-size-sm);margin-bottom:2px}.kyc-card-status{font-size:var(--font-size-xs);white-space:nowrap;overflow:hidden;text-overflow:ellipsis}.kyc-card-status--uploaded{color:var(--color-success, #22c55e)}.kyc-card-status--pending{color:var(--color-text-secondary)}.kyc-card-actions{display:flex;gap:var(--space-sm);flex-shrink:0}.kyc-btn{font-size:var(--font-size-sm);padding:var(--space-xs) var(--space-md)}.kyc-hint{margin-top:var(--space-md);font-size:var(--font-size-xs);color:var(--color-text-secondary)}@media(max-width:600px){.profile-page{max-width:100%}.profile-header{flex-direction:column;align-items:flex-start;gap:var(--space-sm)}.profile-actions{width:100%;justify-content:flex-end}.profile-avatar{width:56px;height:56px;font-size:var(--font-size-2xl)}.profile-fields{grid-template-columns:1fr}}#root{min-height:100vh}
