@import url(https://fonts.googleapis.com/css2?family=Space+Grotesk:wght@400;500;600;700&display=swap);*,:after,:before{box-sizing:border-box;margin:0;padding:0}:root{--sidebar-w:228px;--bg:#07080f;--bg2:#0c0e18;--card:#0f1220;--card2:#141829;--border:#ffffff0f;--border-md:#ffffff1c;--border-light:#ffffff0a;--primary:#6366f1;--primary-dark:#4f46e5;--primary-light:#6366f11f;--text-primary:#e8eaf0;--text-secondary:#7a8799;--text-muted:#3d4f63;--green:#22c55e;--green-bg:#22c55e1a;--red:#f43f5e;--red-bg:#f43f5e1a;--blue:#38bdf8;--blue-bg:#38bdf81a;--amber:#fbbf24;--amber-bg:#fbbf241a;--purple:#a78bfa;--purple-bg:#a78bfa1f;--teal:#2dd4bf;--teal-bg:#2dd4bf1a;--shadow-sm:0 2px 10px #00000080;--shadow-md:0 8px 32px #0009;--shadow-lg:0 20px 64px #000000b3,0 4px 16px #6366f114;--radius:14px;--radius-sm:9px;--radius-xs:6px}body{-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background:#07080f;background:var(--bg);background-image:linear-gradient(hsla(0,0%,100%,.016) 1px,#0000 0),linear-gradient(90deg,hsla(0,0%,100%,.016) 1px,#0000 0);background-size:44px 44px;color:#e8eaf0;color:var(--text-primary);font-family:Space Grotesk,-apple-system,BlinkMacSystemFont,sans-serif;line-height:1.5}::-webkit-scrollbar{height:4px;width:4px}::-webkit-scrollbar-track{background:#0000}::-webkit-scrollbar-thumb{background:#6366f14d;border-radius:4px}::-webkit-scrollbar-thumb:hover{background:#6366f180}*{scrollbar-color:#6366f14d #0000;scrollbar-width:thin}@keyframes pulse{0%,to{opacity:.3}50%{opacity:.7}}@keyframes shimmer{0%{background-position:200% 0}to{background-position:-200% 0}}@keyframes toast-in{0%{opacity:0;transform:translateX(30px)}to{opacity:1;transform:translateX(0)}}@keyframes fade-in{0%{opacity:0}to{opacity:1}}@keyframes slide-up{0%{opacity:0;transform:translateY(16px)}to{opacity:1;transform:translateY(0)}}@keyframes orbFloat1{0%,to{transform:translate(0) scale(1)}33%{transform:translate(50px,30px) scale(1.06)}66%{transform:translate(-25px,50px) scale(.96)}}@keyframes orbFloat2{0%,to{transform:translate(0) scale(1)}33%{transform:translate(-35px,-25px) scale(1.05)}66%{transform:translate(30px,-35px) scale(.97)}}@keyframes live-blink{0%,to{opacity:1}50%{opacity:.3}}.app-shell{display:flex;min-height:100vh}.app-sidebar{backdrop-filter:blur(20px);-webkit-backdrop-filter:blur(20px);background:#090a12f5;border-right:1px solid #ffffff0f;border-right:1px solid var(--border);bottom:0;display:flex;flex-direction:column;left:0;overflow-x:hidden;overflow-y:auto;position:fixed;top:0;width:228px;width:var(--sidebar-w);z-index:600}.sidebar-brand{border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--border);gap:11px;padding:22px 18px 18px}.sidebar-brand,.sidebar-logo-wrap{align-items:center;display:flex;flex-shrink:0}.sidebar-logo-wrap{background:#6366f11f;background:var(--primary-light);border:1px solid #6366f140;border-radius:10px;box-shadow:0 0 16px #6366f133;height:36px;justify-content:center;width:36px}.sidebar-logo{height:22px;object-fit:contain;width:22px}.sidebar-brand-name{-webkit-text-fill-color:#0000;background:linear-gradient(120deg,#fff,#a78bfa);-webkit-background-clip:text;background-clip:text;font-size:.97rem;font-weight:700;line-height:1.15}.sidebar-brand-sub{color:#3d4f63;color:var(--text-muted);font-size:.6rem;font-weight:500;letter-spacing:.06em;text-transform:uppercase}.sidebar-nav{flex-shrink:0;padding:14px 10px 10px}.sidebar-nav-label{color:#3d4f63;color:var(--text-muted);font-size:.59rem;font-weight:700;letter-spacing:.1em;margin-bottom:6px;padding:0 10px;text-transform:uppercase}.sidebar-nav-item{align-items:center;background:#0000;border:none;border-radius:8px;color:#7a8799;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:.84rem;font-weight:500;gap:10px;margin-bottom:2px;padding:9px 10px;text-align:left;transition:all .18s;width:100%}.sidebar-nav-item.active,.sidebar-nav-item:hover{background:#ffffff0d;color:#e8eaf0;color:var(--text-primary)}.sidebar-nav-item.active{background:#6366f11a;color:#a78bfa;color:var(--purple)}.sidebar-nav-dot{background:#6366f1;background:var(--nav-accent,var(--primary));border-radius:50%;flex-shrink:0;height:7px;opacity:.6;transition:opacity .18s,box-shadow .18s;width:7px}.sidebar-nav-item.active .sidebar-nav-dot,.sidebar-nav-item:hover .sidebar-nav-dot{box-shadow:0 0 8px #6366f1;box-shadow:0 0 8px var(--nav-accent,var(--primary));opacity:1}.sidebar-markets{border-top:1px solid #ffffff0f;border-top:1px solid var(--border);flex-shrink:0;padding:12px 0 8px}.sidebar-section-label{color:#3d4f63;color:var(--text-muted);font-size:.59rem;font-weight:700;letter-spacing:.1em;margin-bottom:8px;padding:0 18px;text-transform:uppercase}.sidebar-markets .market-indices-bar{background:#0000;border:none;border-radius:0;box-shadow:none;flex-direction:column;margin:0}.sidebar-markets .market-index-item{align-items:center;border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--border-light);border-right:none;flex-direction:row;gap:6px;justify-content:space-between;padding:7px 18px}.sidebar-markets .market-index-item:last-child{border-bottom:none}.sidebar-markets .market-index-item:hover{background:#ffffff08}.sidebar-markets .index-name{color:#3d4f63;color:var(--text-muted);flex:1 1;font-size:.64rem}.sidebar-markets .index-price{color:#e8eaf0;color:var(--text-primary);font-size:.76rem;font-weight:700}.sidebar-markets .index-change{font-size:.66rem;font-weight:600;min-width:52px;text-align:right}.sidebar-footer{border-top:1px solid #ffffff0f;border-top:1px solid var(--border);display:flex;flex-direction:column;flex-shrink:0;gap:10px;margin-top:auto;padding:14px 12px}.sidebar-user{align-items:center;background:#ffffff08;border:1px solid #ffffff0f;border:1px solid var(--border);border-radius:10px;display:flex;gap:10px;padding:8px}.sidebar-user-info{display:flex;flex-direction:column;gap:1px;min-width:0}.sidebar-user-sub{color:#3d4f63;color:var(--text-muted);font-size:.62rem;font-weight:500;letter-spacing:.04em}.sidebar-logout{justify-content:center;width:100%}.top-nav,.welcome-banner{display:none}.app-main{display:flex;flex:1 1;flex-direction:column;gap:0;margin-left:228px;margin-left:var(--sidebar-w);min-width:0;padding:20px 24px 60px}.hero-bar{align-items:center;background:#0f1220;background:var(--card);border:1px solid #ffffff0f;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 2px 10px #00000080;box-shadow:var(--shadow-sm);display:flex;flex-wrap:wrap;gap:16px;justify-content:space-between;margin-bottom:18px;padding:18px 24px}.hero-greeting{display:flex;flex-direction:column;gap:2px}.hero-label{color:#3d4f63;color:var(--text-muted);font-size:.7rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.hero-name{-webkit-text-fill-color:#0000;background:linear-gradient(120deg,#fff,#a78bfa);-webkit-background-clip:text;background-clip:text;font-size:1.45rem;font-weight:700;line-height:1.1}.hero-right{align-items:center;display:flex;gap:24px}.hero-stat{display:flex;flex-direction:column;gap:2px;text-align:right}.hero-stat-label{color:#3d4f63;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.hero-stat-value{font-feature-settings:"tnum";color:#e8eaf0;color:var(--text-primary);font-size:1.25rem;font-variant-numeric:tabular-nums;font-weight:700;letter-spacing:-.3px}.hero-stat-badge{align-items:center;color:#22c55e;color:var(--green);display:flex;font-size:.78rem;font-weight:700;gap:5px}.hero-stat-badge:before{animation:live-blink 1.8s ease-in-out infinite;background:#22c55e;background:var(--green);border-radius:50%;content:"";display:inline-block;height:7px;width:7px}.hero-divider{background:#ffffff1c;background:var(--border-md);flex-shrink:0;height:36px;width:1px}.content-section{margin-bottom:16px}.component-container{background:#0f1220;background:var(--card);border:1px solid #ffffff0f;border:1px solid var(--border);border-radius:14px;border-radius:var(--radius);box-shadow:0 2px 10px #00000080;box-shadow:var(--shadow-sm);height:100%;overflow:hidden;padding:0;transition:box-shadow .3s,border-color .3s,transform .2s}.component-container:hover{border-color:#6366f138;box-shadow:0 0 0 1px #6366f12e,0 8px 32px #0009;box-shadow:0 0 0 1px #6366f12e,var(--shadow-md);transform:translateY(-1px)}.layout-perf-trade{align-items:stretch;display:flex;gap:16px}.perf-panel{flex:3 1;min-width:0}.trade-col{display:flex;flex:2 1;flex-direction:column;gap:16px;min-width:0}.layout-three-col{align-items:stretch;display:flex;gap:16px}.layout-three-col>*{flex:1 1;min-width:0}.layout-two-col{align-items:flex-start;display:flex;gap:16px}.layout-two-col>*{flex:1 1;min-width:0}.col-stack{display:flex;flex:1 1;flex-direction:column;gap:16px;min-width:0}.section-header{align-items:center;background:#ffffff05;border-bottom:1px solid #ffffff0f;border-bottom:1px solid var(--border);color:#7a8799;color:var(--text-secondary);display:flex;font-size:.72rem;font-weight:700;gap:10px;letter-spacing:.08em;padding:14px 20px;text-transform:uppercase}.section-header:before{border-radius:50%;content:"";flex-shrink:0;height:7px;width:7px}.section-header.green:before{background:#22c55e;background:var(--green);box-shadow:0 0 6px #22c55e;box-shadow:0 0 6px var(--green)}.section-header.red:before{background:#f43f5e;background:var(--red);box-shadow:0 0 6px #f43f5e;box-shadow:0 0 6px var(--red)}.section-header.blue:before{background:#38bdf8;background:var(--blue);box-shadow:0 0 6px #38bdf8;box-shadow:0 0 6px var(--blue)}.section-header.amber:before{background:#fbbf24;background:var(--amber);box-shadow:0 0 6px #fbbf24;box-shadow:0 0 6px var(--amber)}.section-header.purple:before{background:#a78bfa;background:var(--purple);box-shadow:0 0 6px #a78bfa;box-shadow:0 0 6px var(--purple)}.section-header.teal:before{background:#2dd4bf;background:var(--teal);box-shadow:0 0 6px #2dd4bf;box-shadow:0 0 6px var(--teal)}.section-body{padding:18px 20px}.auth-screen{align-items:center;background:#05060d;background-image:linear-gradient(hsla(0,0%,100%,.015) 1px,#0000 0),linear-gradient(90deg,hsla(0,0%,100%,.015) 1px,#0000 0);background-size:44px 44px;display:flex;justify-content:center;min-height:100vh;overflow:hidden;padding:20px;position:relative}.auth-bg-orb{border-radius:50%;filter:blur(120px);pointer-events:none;position:absolute}.auth-orb-1{animation:orbFloat1 24s ease-in-out infinite;background:radial-gradient(circle,#6366f161 0,#0000 65%);height:640px;left:-180px;top:-200px;width:640px}.auth-orb-2{animation:orbFloat2 30s ease-in-out infinite;background:radial-gradient(circle,#2dd4bf38 0,#0000 65%);bottom:-140px;height:500px;right:-130px;width:500px}.auth-card{backdrop-filter:blur(28px);-webkit-backdrop-filter:blur(28px);background:#0f1220eb;border:1px solid #6366f138;border-radius:24px;border-top-color:#6366f166;box-shadow:0 32px 90px #000000bf,0 0 0 1px #6366f114,inset 0 1px 0 #ffffff0f;max-width:420px;padding:44px 40px;position:relative;width:100%;z-index:1}.auth-logo{background:#6366f11f;border:1px solid #6366f14d;border-radius:50%;box-shadow:0 0 30px #6366f14d;height:68px;margin:0 auto 18px;width:68px}.auth-logo,.auth-logo-img{align-items:center;display:flex;justify-content:center}.auth-title{-webkit-text-fill-color:#0000;background:linear-gradient(120deg,#fff,#a78bfa 70%);-webkit-background-clip:text;background-clip:text;font-size:1.75rem;font-weight:700;letter-spacing:-.5px;margin-bottom:6px;text-align:center}.auth-subtitle{color:#ffffff61;font-size:.875rem;letter-spacing:.02em;margin-bottom:32px;text-align:center}.auth-tabs{background:#0000004d;border:1px solid #ffffff0d;border-radius:10px;display:flex;gap:4px;margin-bottom:24px;padding:4px}.auth-tab{background:#0000;border:none;border-radius:7px;color:#ffffff52;cursor:pointer;flex:1 1;font-family:inherit;font-size:.875rem;font-weight:600;letter-spacing:.02em;padding:9px;transition:all .2s}.auth-tab.active{background:#6366f133;box-shadow:0 1px 8px #6366f133;color:#a78bfa}.auth-error{background:#f43f5e14;border:1px solid #f43f5e33;border-left:3px solid #f43f5e;border-left:3px solid var(--red);border-radius:9px;color:#fda4af;font-size:.84rem;margin-bottom:14px;padding:10px 14px}.auth-form{display:flex;flex-direction:column;gap:11px}.auth-form input{background:#0000004d;border:1px solid #ffffff14;border-radius:10px;color:#fff;font-family:inherit;font-size:.92rem;outline:none;padding:13px 16px;transition:border-color .2s,box-shadow .2s,background .2s;width:100%}.auth-form input:focus{background:#0006;border-color:#6366f199;box-shadow:0 0 0 3px #6366f11f}.auth-form input::placeholder{color:#ffffff38}.auth-submit{background:linear-gradient(135deg,#6366f1,#4f46e5);border:none;border-radius:10px;box-shadow:0 4px 20px #6366f173;color:#fff;cursor:pointer;font-family:inherit;font-size:.92rem;font-weight:700;letter-spacing:.03em;margin-top:5px;padding:13px;transition:all .2s;width:100%}.auth-submit:hover:not(:disabled):not(.auth-guest){background:linear-gradient(135deg,#818cf8,#6366f1);box-shadow:0 8px 30px #6366f18c;transform:translateY(-1px)}.auth-submit.auth-guest{background:#ffffff0d;border:1px solid #ffffff1a;box-shadow:none;color:#ffffff73}.auth-submit.auth-guest:hover:not(:disabled){background:#ffffff17;border-color:#ffffff2e;color:#ffffffbf}.auth-submit:disabled{box-shadow:none;cursor:not-allowed;opacity:.35;transform:none}.auth-hint{color:#ffffff40;font-size:.8rem;line-height:1.65;margin-top:20px;text-align:center}.auth-cold-start-note{background:#0003;border:1px solid #ffffff0d;border-radius:7px;color:#ffffff2e;font-size:.72rem;line-height:1.5;margin-top:12px;padding:8px 12px;text-align:center}.error-banner{background:#f43f5e1a;background:var(--red-bg);border:1px solid #f43f5e33;border-left:3px solid #f43f5e;border-left:3px solid var(--red);border-radius:9px;border-radius:var(--radius-sm);color:#fda4af;font-size:.88rem;font-weight:600;margin-bottom:16px;padding:12px 18px}.error-details{font-size:.82rem;font-weight:400;list-style-type:disc;margin-left:20px;margin-top:8px;opacity:.75}.loading{color:#3d4f63;color:var(--text-muted);font-size:.88rem;letter-spacing:.1em;padding:60px;text-align:center;text-transform:uppercase}.market-indices-bar{background:#0f1220;background:var(--card);border:1px solid #ffffff0f;border:1px solid var(--border);border-radius:9px;border-radius:var(--radius-sm);box-shadow:0 2px 10px #00000080;box-shadow:var(--shadow-sm);display:flex;overflow:hidden;width:100%}.market-index-item{align-items:center;border-right:1px solid #ffffff0a;border-right:1px solid var(--border-light);display:flex;flex:1 1;flex-direction:column;gap:2px;padding:10px 14px;transition:background .2s}.market-index-item:last-child{border-right:none}.market-index-item:hover{background:#ffffff08}.index-name{color:#3d4f63;color:var(--text-muted);font-size:.62rem;font-weight:600;letter-spacing:.1em;text-transform:uppercase}.index-price{font-feature-settings:"tnum";color:#e8eaf0;color:var(--text-primary);font-size:.87rem;font-variant-numeric:tabular-nums;font-weight:700}.index-change{font-feature-settings:"tnum";font-size:.7rem;font-variant-numeric:tabular-nums;font-weight:600}.index-up{color:#22c55e;color:var(--green)}.index-down{color:#f43f5e;color:var(--red)}.trade-form .input-group{display:flex;flex-direction:column;gap:10px}.trade-form input{background:#0c0e18;background:var(--bg2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:9px;border-radius:var(--radius-sm);color:#e8eaf0;color:var(--text-primary);font-family:inherit;font-size:.9rem;outline:none;padding:11px 14px;transition:border-color .2s,box-shadow .2s;width:100%}.trade-form input:focus{background:#141829;background:var(--card2);border-color:#6366f180;box-shadow:0 0 0 3px #6366f11a}.trade-form input::placeholder{color:#3d4f63;color:var(--text-muted)}.trade-form button{border:none;border-radius:9px;border-radius:var(--radius-sm);color:#fff;cursor:pointer;font-family:inherit;font-size:.92rem;font-weight:700;letter-spacing:.03em;margin-top:6px;padding:12px;transition:all .2s;width:100%}.trade-form button.buy-btn{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 20px #22c55e4d}.trade-form button.buy-btn:hover:not(:disabled){box-shadow:0 8px 28px #22c55e66;transform:translateY(-1px)}.trade-form button.sell-btn{background:linear-gradient(135deg,#f43f5e,#e11d48);box-shadow:0 4px 20px #f43f5e4d}.trade-form button.sell-btn:hover:not(:disabled){box-shadow:0 8px 28px #f43f5e66;transform:translateY(-1px)}.trade-form button:disabled{box-shadow:none;cursor:not-allowed;opacity:.35;transform:none}.trade-form .form-error{background:#f43f5e1a;background:var(--red-bg);border:1px solid #f43f5e33;border-left:3px solid #f43f5e;border-left:3px solid var(--red);border-radius:6px;border-radius:var(--radius-xs);color:#fda4af;font-size:.85rem;padding:10px 14px}.trade-form .form-success{background:#22c55e1a;background:var(--green-bg);border:1px solid #22c55e33;border-left:3px solid #22c55e;border-left:3px solid var(--green);border-radius:6px;border-radius:var(--radius-xs);color:#86efac;font-size:.85rem;padding:10px 14px}.price-preview{display:flex;flex-wrap:wrap;font-size:.82rem;gap:16px;margin-top:8px;padding:8px 2px 2px}.preview-price{color:#7a8799;color:var(--text-secondary);font-weight:500}.preview-cost{color:#22c55e;color:var(--green);font-weight:600}.preview-loading,.preview-unknown{color:#3d4f63;color:var(--text-muted);font-style:italic}.news-card{border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--border-light);color:#e8eaf0;color:var(--text-primary);display:block;padding:11px 0;text-decoration:none;transition:color .15s}.news-card:last-child{border-bottom:none}.news-card:hover{color:#a78bfa;color:var(--purple)}.news-card .news-title{font-size:.86rem;font-weight:600;line-height:1.45}.news-scroll-list{max-height:375px;overflow-y:auto;padding-right:2px}.news-empty{color:#3d4f63;color:var(--text-muted);font-size:.88rem;padding:20px 0;text-align:center}.news-buttons{display:flex;gap:8px;justify-content:center;padding:12px 0 4px}.news-toggle-btn{background:none;border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:6px;border-radius:var(--radius-xs);color:#7a8799;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.78rem;font-weight:600;letter-spacing:.03em;padding:5px 14px;transition:all .2s}.news-toggle-btn:hover{background:#6366f11f;background:var(--primary-light);border-color:#6366f1;border-color:var(--primary);color:#a78bfa;color:var(--purple)}.news-empty-state{align-items:center;display:flex;flex-direction:column;gap:8px;padding:28px 16px}.news-empty-icon{font-size:2rem}.news-empty-text{color:#7a8799;color:var(--text-secondary);font-size:.88rem}.news-empty-sub{color:#3d4f63;color:var(--text-muted);font-size:.78rem}.chart-stock-buttons{-ms-overflow-style:none;display:flex;gap:6px;margin-bottom:16px;overflow-x:auto;padding-bottom:2px;scrollbar-width:none}.chart-stock-buttons::-webkit-scrollbar{display:none}.chart-stock-btn{background:#141829;background:var(--card2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:20px;color:#7a8799;color:var(--text-secondary);cursor:pointer;flex-shrink:0;font-family:inherit;font-size:.78rem;font-weight:600;letter-spacing:.04em;padding:5px 14px;transition:all .2s}.chart-stock-btn:hover{background:#6366f11f;background:var(--primary-light);color:#a78bfa;color:var(--purple)}.chart-stock-btn.active,.chart-stock-btn:hover{border-color:#6366f1;border-color:var(--primary)}.chart-stock-btn.active{background:#6366f1;background:var(--primary);box-shadow:0 2px 12px #6366f166;color:#fff}.chart-container{height:340px;position:relative}.chart-loading{color:#3d4f63;color:var(--text-muted);font-size:.88rem;padding:40px 0;text-align:center}.popular-stocks-wrapper{display:flex;flex-direction:column;height:100%}.popular-stocks-body{display:flex;flex:1 1;flex-direction:column}.popular-stocks-grid{align-content:center;display:flex;flex:1 1;flex-wrap:wrap;gap:8px;justify-content:center}.stock-chip{background:#141829;background:var(--card2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:20px;color:#7a8799;color:var(--text-secondary);display:inline-block;font-size:.79rem;font-weight:700;letter-spacing:.04em;padding:6px 14px;text-decoration:none;transition:all .2s}.stock-chip:hover{background:#6366f11f;background:var(--primary-light);border-color:#6366f166;box-shadow:0 4px 16px #6366f133;color:#a78bfa;color:var(--purple);transform:translateY(-2px)}.leaderboard-list{list-style:none;margin:0;padding:0}.leaderboard-item{align-items:center;border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;padding:10px 0}.leaderboard-item:last-child{border-bottom:none}.leaderboard-rank{align-items:center;border-radius:50%;display:flex;flex-shrink:0;font-size:.75rem;font-weight:800;height:28px;justify-content:center;width:28px}.leaderboard-rank.gold{background:linear-gradient(135deg,#fbbf24,#d97706);box-shadow:0 2px 10px #fbbf2473;color:#000}.leaderboard-rank.silver{background:linear-gradient(135deg,#94a3b8,#64748b);color:#fff}.leaderboard-rank.bronze{background:linear-gradient(135deg,#f59e0b,#b45309);box-shadow:0 2px 8px #b453094d;color:#fff}.leaderboard-rank.default{background:#ffffff0d;border:1px solid #ffffff1c;border:1px solid var(--border-md);color:#3d4f63;color:var(--text-muted)}.leaderboard-name{color:#e8eaf0;color:var(--text-primary);flex:1 1;font-size:.87rem;font-weight:600;margin-left:10px}.leaderboard-balance{font-feature-settings:"tnum";color:#22c55e;color:var(--green);font-size:.87rem;font-variant-numeric:tabular-nums;font-weight:700}.transaction-scroll{max-height:420px;overflow-y:auto}.transaction-table{border-collapse:initial;border-spacing:0 4px;font-size:.86rem;table-layout:fixed;width:100%}.transaction-table thead th{background:#0f1220;background:var(--card);color:#3d4f63;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.09em;padding:4px 10px 10px;position:sticky;text-align:left;text-transform:uppercase;top:0;z-index:1}.transaction-table tbody tr{background:hsla(0,0%,100%,.025);transition:background .15s}.transaction-table tbody tr:hover{background:#6366f10f}.transaction-table tbody td{color:#7a8799;color:var(--text-secondary);padding:12px 10px}.transaction-table tbody td:first-child{border-radius:8px 0 0 8px}.transaction-table tbody td:last-child{border-radius:0 8px 8px 0}.transaction-table .type-cell{text-align:center}.transaction-table .type-buy,.transaction-table .type-sell{align-items:center;border-radius:20px;display:inline-flex;font-size:.68rem;font-weight:700;justify-content:center;letter-spacing:.08em;min-width:52px;padding:4px 12px}.transaction-table .type-buy{background:#22c55e26;border:1px solid #22c55e40;color:#22c55e;color:var(--green)}.transaction-table .type-sell{background:#f43f5e26;border:1px solid #f43f5e40;color:#f43f5e;color:var(--red)}.toast-container{display:flex;flex-direction:column;gap:10px;pointer-events:none;position:fixed;right:20px;top:20px;z-index:1000}.toast{animation:toast-in .25s ease;border-radius:10px;box-shadow:0 20px 64px #000000b3,0 4px 16px #6366f114;box-shadow:var(--shadow-lg);font-size:.85rem;font-weight:500;max-width:300px;padding:12px 18px;pointer-events:auto}.toast-success{border:1px solid #22c55e33;border-left:3px solid #22c55e;border-left:3px solid var(--green);color:#22c55e;color:var(--green)}.toast-error,.toast-success{background:#141829;background:var(--card2)}.toast-error{border:1px solid #f43f5e33;border-left:3px solid #f43f5e;border-left:3px solid var(--red);color:#f43f5e;color:var(--red)}.skeleton{animation:shimmer 1.8s infinite;background:linear-gradient(90deg,#0f1220 25%,#1a1d2e 50%,#0f1220 75%);background-size:200% 100%;border-radius:6px}.skeleton-card{display:flex;flex-direction:column;gap:10px;height:120px;min-width:220px;padding:16px}.skeleton-title{height:16px;width:50%}.skeleton-line{height:12px;width:72%}.skeleton-line.short{width:42%}.pnl-badge{font-feature-settings:"tnum";align-items:center;border-radius:12px;display:inline-flex;font-size:.72rem;font-variant-numeric:tabular-nums;font-weight:700;gap:4px;margin-bottom:10px;padding:3px 8px}.pnl-up{background:#22c55e1a;background:var(--green-bg);border:1px solid #22c55e33;color:#22c55e;color:var(--green)}.pnl-down{background:#f43f5e1a;background:var(--red-bg);border:1px solid #f43f5e33;color:#f43f5e;color:var(--red)}.pnl-abs{font-weight:400;opacity:.8}.modal-overlay{align-items:center;animation:fade-in .15s ease;-webkit-backdrop-filter:blur(8px);backdrop-filter:blur(8px);background:#000000b3;display:flex;inset:0;justify-content:center;position:fixed;z-index:900}.modal-card{animation:slide-up .2s ease;background:#0f1220;background:var(--card);border:1px solid #6366f140;border-radius:18px;box-shadow:0 32px 80px #000000b3,0 0 0 1px #6366f11a;max-width:380px;min-width:300px;padding:28px;width:90%}.modal-title{color:#e8eaf0;color:var(--text-primary);font-size:1.05rem;font-weight:700;margin:0 0 20px}.modal-detail-row{align-items:center;border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--border-light);display:flex;font-size:.86rem;justify-content:space-between;padding:8px 0}.modal-detail-row.modal-total{border-bottom:none;font-weight:600;padding-top:14px}.modal-label{color:#3d4f63;color:var(--text-muted)}.modal-value{font-feature-settings:"tnum";color:#e8eaf0;color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:500}.modal-value.cost{color:#f43f5e;color:var(--red)}.modal-value.revenue{color:#22c55e;color:var(--green)}.modal-actions{display:flex;gap:10px;margin-top:22px}.modal-btn{border:none;border-radius:9px;border-radius:var(--radius-sm);cursor:pointer;flex:1 1;font-family:inherit;font-size:.9rem;font-weight:700;letter-spacing:.03em;padding:11px;transition:opacity .15s,transform .15s}.modal-btn:hover{opacity:.88;transform:translateY(-1px)}.modal-btn.cancel{background:#ffffff0d;border:1px solid #ffffff1c;border:1px solid var(--border-md);color:#7a8799;color:var(--text-secondary)}.modal-btn.confirm.buy{background:linear-gradient(135deg,#22c55e,#16a34a);box-shadow:0 4px 16px #22c55e4d;color:#fff}.modal-btn.confirm.sell{background:linear-gradient(135deg,#f43f5e,#e11d48);box-shadow:0 4px 16px #f43f5e4d;color:#fff}.portfolio-allocation-section{border-top:1px solid #ffffff0a;margin-top:10px;padding:18px 0 4px}.allocation-heading{color:#3d4f63}.allocation-wrapper{align-items:center;display:flex;flex-wrap:wrap;gap:24px}.allocation-chart{flex-shrink:0;height:130px;width:130px}.allocation-legend{display:flex;flex:1 1;flex-wrap:wrap;gap:8px 20px;min-width:0}.allocation-legend-row{align-items:center;display:flex;font-size:.79rem;gap:6px}.allocation-dot{border-radius:50%;flex-shrink:0;height:8px;width:8px}.allocation-sym{color:#e8eaf0;color:var(--text-primary);font-weight:700}.allocation-pct{color:#3d4f63;color:var(--text-muted)}.perf-summary{display:flex;flex-wrap:wrap;gap:30px;margin-bottom:16px}.perf-stat{display:flex;flex-direction:column;gap:3px}.perf-label{color:#3d4f63;color:var(--text-muted);font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.perf-value{font-feature-settings:"tnum";color:#e8eaf0;color:var(--text-primary);font-size:1.08rem;font-variant-numeric:tabular-nums;font-weight:700}.perf-up{color:#22c55e;color:var(--green)}.perf-down{color:#f43f5e;color:var(--red)}.stock-search-form{display:flex;gap:8px;margin-bottom:10px}.stock-search-input{background:#0c0e18;background:var(--bg2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:9px;border-radius:var(--radius-sm);color:#e8eaf0;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.88rem;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.stock-search-input:focus{background:#141829;background:var(--card2);border-color:#6366f180;box-shadow:0 0 0 3px #6366f11a}.stock-search-input::placeholder{color:#3d4f63;color:var(--text-muted)}.stock-search-btn{background:#6366f1;background:var(--primary);border:none;border-radius:9px;border-radius:var(--radius-sm);box-shadow:0 3px 12px #6366f14d;color:#fff;cursor:pointer;font-family:inherit;font-size:.84rem;font-weight:700;letter-spacing:.03em;padding:10px 16px;transition:all .2s;white-space:nowrap}.stock-search-btn:hover{box-shadow:0 6px 20px #6366f166;opacity:.9;transform:translateY(-1px)}.search-error{color:#f43f5e;color:var(--red);font-size:.82rem;margin:4px 0 0}.search-result-card{align-items:center;background:#141829;background:var(--card2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:9px;border-radius:var(--radius-sm);display:flex;justify-content:space-between;margin-top:8px;padding:12px 14px}.search-result-left{display:flex;flex-direction:column;gap:2px}.search-result-symbol{color:#e8eaf0;color:var(--text-primary);font-size:1.05rem;font-weight:800}.search-result-label{color:#3d4f63;color:var(--text-muted);font-size:.65rem;letter-spacing:.07em;text-transform:uppercase}.search-result-right{align-items:flex-end;display:flex;flex-direction:column;gap:6px}.search-result-price{font-feature-settings:"tnum";color:#e8eaf0;color:var(--text-primary);font-size:1.05rem;font-variant-numeric:tabular-nums;font-weight:700}.watchlist-toggle-btn{background:#0f1220;background:var(--card);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:6px;border-radius:var(--radius-xs);color:#7a8799;color:var(--text-secondary);cursor:pointer;font-family:inherit;font-size:.75rem;font-weight:600;padding:4px 10px;transition:all .2s}.watchlist-toggle-btn:hover:not(:disabled){border-color:#22c55e;border-color:var(--green);color:#22c55e;color:var(--green)}.watchlist-toggle-btn.watching{background:#22c55e1a;background:var(--green-bg);border-color:#22c55e4d;color:#22c55e;color:var(--green);cursor:default}.sim-description{color:#3d4f63;color:var(--text-muted);font-size:.82rem;line-height:1.55;margin-bottom:14px}.horizon-select{appearance:none;background:#0c0e18;background:var(--bg2);background-image:url("data:image/svg+xml;charset=utf-8,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12'%3E%3Cpath fill='%233d4f63' d='M6 8 1 3h10z'/%3E%3C/svg%3E");background-position:right 14px center;background-repeat:no-repeat;border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:9px;border-radius:var(--radius-sm);color:#e8eaf0;color:var(--text-primary);cursor:pointer;font-family:inherit;font-size:.9rem;font-weight:500;outline:none;padding:11px 36px 11px 14px;transition:border-color .2s,box-shadow .2s;width:100%}.horizon-select:focus{background-color:#141829;background-color:var(--card2);border-color:#fbbf2480;box-shadow:0 0 0 3px #fbbf241a}.simulate-btn{background:linear-gradient(135deg,#fbbf24,#d97706);border:none;border-radius:9px;border-radius:var(--radius-sm);box-shadow:0 4px 16px #fbbf244d;color:#000;cursor:pointer;font-family:inherit;font-size:.92rem;font-weight:700;letter-spacing:.03em;margin-top:4px;padding:12px;transition:all .2s;width:100%}.simulate-btn:hover:not(:disabled){box-shadow:0 8px 24px #fbbf2466;transform:translateY(-1px)}.simulate-btn:disabled{cursor:not-allowed;opacity:.35}.simulation-result{background:#141829;background:var(--card2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:9px;border-radius:var(--radius-sm);margin-top:16px;overflow:hidden}.sim-row{align-items:center;border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--border-light);display:flex;font-size:.86rem;justify-content:space-between;padding:9px 14px}.sim-row-total{border-bottom:none;font-weight:600}.sim-label{color:#3d4f63;color:var(--text-muted)}.sim-val{font-feature-settings:"tnum";color:#e8eaf0;color:var(--text-primary);font-variant-numeric:tabular-nums;font-weight:600}.sim-up{color:#22c55e;color:var(--green)}.sim-down{color:#f43f5e;color:var(--red)}.sim-disclaimer{border-top:1px solid #ffffff0a;border-top:1px solid var(--border-light);color:#3d4f63;color:var(--text-muted);font-size:.68rem;font-style:italic;padding:8px 14px;text-align:center}.watchlist-form{display:flex;gap:8px;margin-bottom:14px}.watchlist-input{background:#0c0e18;background:var(--bg2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:9px;border-radius:var(--radius-sm);color:#e8eaf0;color:var(--text-primary);flex:1 1;font-family:inherit;font-size:.88rem;outline:none;padding:10px 14px;transition:border-color .2s,box-shadow .2s}.watchlist-input:focus{background:#141829;background:var(--card2);border-color:#22c55e80;box-shadow:0 0 0 3px #22c55e1a}.watchlist-input::placeholder{color:#3d4f63;color:var(--text-muted)}.watchlist-add-btn{background:linear-gradient(135deg,#22c55e,#16a34a);border:none;border-radius:9px;border-radius:var(--radius-sm);box-shadow:0 3px 12px #22c55e40;color:#fff;cursor:pointer;font-family:inherit;font-size:.84rem;font-weight:700;padding:10px 14px;transition:all .2s}.watchlist-add-btn:hover{opacity:.9;transform:translateY(-1px)}.watchlist-empty{color:#3d4f63;color:var(--text-muted);font-size:.86rem;padding:16px 0;text-align:center}.watchlist-list{list-style:none;margin:0;padding:0}.watchlist-item{align-items:center;border-bottom:1px solid #ffffff0a;border-bottom:1px solid var(--border-light);display:flex;gap:10px;padding:9px 0}.watchlist-item:last-child{border-bottom:none}.watchlist-symbol{color:#e8eaf0;color:var(--text-primary);flex:1 1;font-size:.87rem;font-weight:700}.watchlist-price{font-feature-settings:"tnum";color:#22c55e;color:var(--green);font-size:.87rem;font-variant-numeric:tabular-nums;font-weight:700}.watchlist-remove{background:none;border:none;border-radius:6px;border-radius:var(--radius-xs);color:#3d4f63;color:var(--text-muted);cursor:pointer;font-family:inherit;font-size:.85rem;padding:4px 6px;transition:background .15s,color .15s}.watchlist-remove:hover{background:#f43f5e1a;background:var(--red-bg);color:#f43f5e;color:var(--red)}.stats-grid{-ms-overflow-style:none;display:flex;gap:10px;overflow-x:auto;padding-bottom:4px;scrollbar-width:none}.stats-grid::-webkit-scrollbar{display:none}.stat-card{background:#141829;background:var(--card2);border:1px solid #ffffff0f;border:1px solid var(--border);border-radius:9px;border-radius:var(--radius-sm);display:flex;flex-direction:column;flex-shrink:0;gap:4px;min-width:148px;padding:14px 16px;transition:border-color .2s,box-shadow .2s}.stat-card:hover{border-color:#6366f14d;box-shadow:0 0 0 1px #6366f11a,0 2px 10px #00000080;box-shadow:0 0 0 1px #6366f11a,var(--shadow-sm)}.stat-label{cursor:default;font-size:.68rem;font-weight:600;letter-spacing:.08em;text-transform:uppercase}.stat-label,.stat-tip-icon{color:#3d4f63;color:var(--text-muted)}.stat-tip-icon{align-items:center;background:#0c0e18;background:var(--bg2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:50%;display:inline-flex;font-size:.65rem;font-style:normal;height:13px;justify-content:center;margin-left:3px;vertical-align:middle;width:13px}.stat-value{font-feature-settings:"tnum";color:#e8eaf0;color:var(--text-primary);font-size:.97rem;font-variant-numeric:tabular-nums;font-weight:700}.stat-up{color:#22c55e;color:var(--green)}.stat-down{color:#f43f5e;color:var(--red)}.achievements-grid{display:flex;flex-wrap:wrap;gap:10px;margin-bottom:14px}.achievement-badge{align-items:center;background:#141829;background:var(--card2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:12px;cursor:default;display:flex;flex-direction:column;gap:4px;min-width:80px;padding:12px 14px;text-align:center;transition:transform .15s,box-shadow .15s}.achievement-badge:hover{box-shadow:0 2px 10px #00000080;box-shadow:var(--shadow-sm);transform:translateY(-2px)}.achievement-badge.unlocked{background:#2dd4bf1a;background:var(--teal-bg);border-color:#2dd4bf40}.achievement-badge.locked{opacity:.35}.achievement-icon{font-size:1.5rem}.achievement-name{color:#7a8799;color:var(--text-secondary);font-size:.68rem;font-weight:600}.achievement-count{color:#3d4f63;color:var(--text-muted);font-size:.78rem}.tooltip-wrapper{display:inline-block}.tooltip-bubble{background:#141829;background:var(--card2);border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:6px;border-radius:var(--radius-xs);box-shadow:0 8px 32px #0009;box-shadow:var(--shadow-md);color:#e8eaf0;color:var(--text-primary);font-size:.72rem;font-weight:400;padding:5px 10px;pointer-events:none;transform:translate(-50%,calc(-100% - 8px));white-space:nowrap;z-index:9999}.tooltip-bubble:after{border:5px solid #0000;border-top:5px solid var(--card2);content:"";left:50%;position:absolute;top:100%;transform:translateX(-50%)}.csv-export-btn{background:#a78bfa1f;background:var(--purple-bg);border:1px solid #a78bfa40;border-radius:6px;border-radius:var(--radius-xs);color:#a78bfa;color:var(--purple);cursor:pointer;font-family:inherit;font-size:.7rem;font-weight:600;letter-spacing:.04em;padding:4px 12px;transition:all .2s}.csv-export-btn:hover{background:#a78bfa2e;border-color:#a78bfa66}.scroll-nav{display:none}.nav-skeleton{animation:pulse 1.5s ease infinite;background:#141829;background:var(--card2);border-radius:10px;height:40px;width:100%}.nav-avatar{align-items:center;background:linear-gradient(135deg,#6366f1,#4f46e5);border-radius:50%;box-shadow:0 0 10px #6366f166;color:#fff;display:flex;flex-shrink:0;font-size:.75rem;font-weight:700;height:30px;justify-content:center;width:30px}.nav-username{color:#e8eaf0;color:var(--text-primary);font-size:.84rem;font-weight:600}.logout-btn{align-items:center;background:#0000;border:1px solid #ffffff1c;border:1px solid var(--border-md);border-radius:8px;color:#7a8799;color:var(--text-secondary);cursor:pointer;display:flex;font-family:inherit;font-size:.81rem;font-weight:600;gap:6px;justify-content:center;padding:8px 14px;transition:all .2s;white-space:nowrap;width:100%}.logout-btn:hover{background:#f43f5e1a;background:var(--red-bg);border-color:#f43f5e;border-color:var(--red);color:#f43f5e;color:var(--red)}@media (max-width:1000px){:root{--sidebar-w:0px}.app-sidebar{display:none}.app-main{margin-left:0;padding:16px 14px 60px}.layout-perf-trade,.layout-three-col,.layout-two-col{flex-direction:column}.chart-container{height:260px}.hero-bar{align-items:flex-start;flex-direction:column}}@media (max-width:620px){.auth-card{padding:32px 24px}.hero-right{flex-wrap:wrap;gap:16px}}.portfolio-container{padding:22px;width:100%}.portfolio-header{align-items:flex-end;border-bottom:1px solid var(--border);display:flex;flex-wrap:wrap;gap:12px;justify-content:space-between;margin-bottom:16px;padding:0 0 18px}.portfolio-title{color:var(--text-primary);font-size:1.12rem;font-weight:700;letter-spacing:-.2px;margin:0}.portfolio-summary{display:flex;gap:28px;text-align:center}.summary-item{display:flex;flex-direction:column;gap:3px;text-align:right}.summary-label{color:var(--text-muted);font-size:.65rem;font-weight:600;letter-spacing:.09em;text-transform:uppercase}.summary-value{font-feature-settings:"tnum";color:var(--text-primary);font-size:1.3rem;font-variant-numeric:tabular-nums;font-weight:700;letter-spacing:-.3px}.portfolio-carousel{align-items:center;display:flex;position:relative}.portfolio-scroll{-ms-overflow-style:none;display:flex;gap:12px;overflow-x:auto;padding:4px 4px 10px;scroll-behavior:smooth;scrollbar-width:none}.portfolio-scroll::-webkit-scrollbar{display:none}.carousel-arrow{align-items:center;background:var(--card2);border:1px solid var(--border-md);border-radius:50%;box-shadow:var(--shadow-md);color:var(--text-secondary);cursor:pointer;display:flex;font-size:1.1rem;height:30px;justify-content:center;line-height:1;position:absolute;top:50%;transform:translateY(-50%);transition:all .2s;width:30px;z-index:2}.carousel-arrow:hover{background:var(--primary);border-color:var(--primary);box-shadow:0 4px 18px #6366f173;color:#fff;transform:translateY(-50%) scale(1.1)}.carousel-arrow-left{left:-10px}.carousel-arrow-right{right:-10px}.stock-card{background:var(--card2);border:1px solid var(--border);border-radius:11px;border-top:2px solid var(--primary);box-shadow:var(--shadow-sm);flex-shrink:0;min-width:216px;padding:16px;transition:all .25s ease}.stock-card:hover{border-color:#818cf8 #6366f159 #6366f159;box-shadow:0 0 0 1px #6366f14d,var(--shadow-md);transform:translateY(-3px)}.stock-header{align-items:flex-start;display:flex;justify-content:space-between;margin-bottom:12px}.stock-symbol{color:var(--text-primary);font-size:1.15rem;font-weight:700;letter-spacing:-.1px}.stock-shares{background:#ffffff0d;border:1px solid var(--border-md);border-radius:12px;color:var(--text-muted);font-size:.72rem;font-weight:600;padding:2px 9px}.stock-details{margin-bottom:0}.detail-row{align-items:center;border-bottom:1px solid var(--border-light);display:flex;justify-content:space-between;margin-bottom:7px;padding-bottom:7px}.detail-row:last-child{border-bottom:none;margin-bottom:0;padding-bottom:0}.detail-label{color:var(--text-muted);font-size:.74rem;font-weight:500}.detail-value{font-feature-settings:"tnum";color:var(--text-primary);font-size:.86rem;font-variant-numeric:tabular-nums;font-weight:700}.empty-portfolio{background:#ffffff05;border:1px dashed #ffffff1a;border-radius:10px;padding:36px 20px;text-align:center}.empty-portfolio p{color:var(--text-secondary);font-size:.93rem;font-weight:500;margin-bottom:6px}.empty-portfolio .hint{color:var(--text-muted);font-size:.82rem}.portfolio-allocation-section{border-top:1px solid var(--border-light);margin-top:8px;padding:18px 0 6px}.allocation-heading{color:var(--text-muted);font-size:.68rem;font-weight:700;letter-spacing:.09em;margin-bottom:14px;text-transform:uppercase}@media (max-width:768px){.portfolio-header{flex-direction:column;text-align:center}.portfolio-summary{flex-direction:column;gap:12px}.stock-card{min-width:190px}}
/*# sourceMappingURL=main.835f8930.css.map*/