@import"https://fonts.googleapis.com/css2?family=Bricolage+Grotesque:opsz,wght@12..96,400;12..96,500;12..96,600;12..96,700;12..96,800&family=DM+Sans:wght@300;400;500;600&family=IBM+Plex+Mono:wght@300;400;500&display=swap";*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #f5f7fa;--bg-elevated: #ffffff;--bg-card: #ffffff;--border: #e4e8ef;--border-subtle: #eef1f6;--text: #0f1623;--text-secondary: #5a6478;--text-tertiary: #b8c0cc;--green: #059669;--green-dim: rgba(5, 150, 105, .08);--red: #dc2626;--red-dim: rgba(220, 38, 38, .08);--blue: #2563eb;--blue-dim: rgba(37, 99, 235, .08);--shadow-sm: 0 1px 3px rgba(15, 22, 35, .06), 0 1px 2px rgba(15, 22, 35, .04);--shadow-md: 0 4px 16px rgba(15, 22, 35, .08), 0 2px 6px rgba(15, 22, 35, .05);--shadow-lg: 0 12px 40px rgba(15, 22, 35, .1), 0 4px 12px rgba(15, 22, 35, .06);--font-display: "Bricolage Grotesque", sans-serif;--font-body: "DM Sans", sans-serif;--font-mono: "IBM Plex Mono", monospace;--header-h: 64px}html{font-family:var(--font-body);background:var(--bg);color:var(--text);-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;scroll-behavior:smooth}body{min-height:100vh;background:var(--bg)}#app{min-height:100vh}a{color:inherit;text-decoration:none}button{cursor:pointer;font-family:var(--font-body)}.app-shell{display:flex;flex-direction:column;min-height:100vh}.main-content{flex:1;padding-top:var(--header-h)}.header{position:fixed;top:0;left:0;right:0;z-index:100;height:var(--header-h);background:#ffffffeb;backdrop-filter:blur(16px);-webkit-backdrop-filter:blur(16px);border-bottom:1px solid var(--border-subtle);transition:border-color .3s ease,box-shadow .3s ease}.header.scrolled{border-bottom-color:var(--border);box-shadow:0 1px 12px #0f16230f}.header-inner{max-width:1280px;margin:0 auto;padding:0 40px;height:100%;display:flex;align-items:center;justify-content:space-between;gap:32px}.logo{display:flex;align-items:center;gap:10px;cursor:pointer;-webkit-user-select:none;user-select:none;flex-shrink:0}.logo-icon{width:32px;height:32px;background:var(--green);display:flex;align-items:center;justify-content:center;border-radius:8px;box-shadow:0 2px 8px #0596694d}.logo-icon svg{width:18px;height:18px}.logo-name{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.02em}.market-status{display:flex;align-items:center;gap:6px;padding:4px 10px;border:1px solid rgba(5,150,105,.2);border-radius:100px;background:var(--green-dim)}.status-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:status-pulse 2s ease-in-out infinite}@keyframes status-pulse{0%,to{opacity:1}50%{opacity:.4}}.status-text{font-family:var(--font-mono);font-size:10px;letter-spacing:.08em;color:var(--green);text-transform:uppercase;font-weight:500}.nav{display:flex;align-items:center;gap:2px;flex:1;justify-content:center}.nav-link{font-family:var(--font-body);font-size:14px;font-weight:500;color:var(--text-secondary);padding:6px 14px;border-radius:6px;transition:color .2s ease,background .2s ease}.nav-link:hover{color:var(--text);background:var(--bg)}.nav-link.active{color:var(--text);background:var(--bg);font-weight:600}.nav-actions{display:flex;align-items:center;gap:8px;flex-shrink:0}.btn-login{background:transparent;border:1px solid var(--border);color:var(--text);font-family:var(--font-body);font-size:14px;font-weight:500;padding:8px 16px;border-radius:8px;transition:background .2s ease,border-color .2s ease}.btn-login:hover{background:var(--bg);border-color:var(--text-tertiary)}.btn-open-account{background:var(--green);border:none;color:#fff;font-family:var(--font-body);font-size:14px;font-weight:600;padding:8px 20px;border-radius:8px;box-shadow:0 2px 8px #05966940;transition:opacity .2s ease,transform .2s ease,box-shadow .2s ease}.btn-open-account:hover{opacity:.9;transform:translateY(-1px);box-shadow:0 4px 14px #05966959}.user-info{display:flex;align-items:center;gap:8px}.user-avatar{width:30px;height:30px;border-radius:50%;background:var(--green-dim);border:1.5px solid rgba(5,150,105,.2);display:flex;align-items:center;justify-content:center;font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--green)}.user-name{font-family:var(--font-body);font-size:14px;font-weight:600;color:var(--text)}.footer{border-top:1px solid var(--border);background:var(--bg-elevated)}.footer-inner{max-width:1280px;margin:0 auto;padding:48px 40px 32px}.footer-top{display:grid;grid-template-columns:1fr 1fr 1fr 1fr;gap:40px;padding-bottom:40px;border-bottom:1px solid var(--border);margin-bottom:28px}.footer-brand .footer-logo{display:flex;align-items:center;gap:8px;margin-bottom:12px}.footer-logo-icon{width:26px;height:26px;background:var(--green);border-radius:6px;display:flex;align-items:center;justify-content:center;box-shadow:0 2px 6px #05966940}.footer-logo-icon svg{width:14px;height:14px}.footer-logo-name{font-family:var(--font-display);font-size:16px;font-weight:700;color:var(--text);letter-spacing:-.02em}.footer-tagline{font-size:13px;line-height:1.6;color:var(--text-secondary);max-width:200px}.footer-col-title{font-family:var(--font-body);font-size:12px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--text);margin-bottom:16px}.footer-links{list-style:none;display:flex;flex-direction:column;gap:10px}.footer-links li a{font-size:13px;color:var(--text-secondary);transition:color .2s ease}.footer-links li a:hover{color:var(--text)}.footer-bottom{display:flex;align-items:center;justify-content:space-between}.footer-copy{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);letter-spacing:.04em}.footer-disclaimer{font-size:11px;color:var(--text-tertiary);max-width:480px;text-align:right;line-height:1.5}.dashboard{max-width:1280px;margin:0 auto;padding:36px 40px 80px}.page-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:32px}.page-title{font-family:var(--font-display);font-size:26px;font-weight:800;color:var(--text);letter-spacing:-.03em}.page-meta{display:flex;align-items:center;gap:12px}.market-badge{display:flex;align-items:center;gap:6px;background:var(--green-dim);border:1px solid rgba(5,150,105,.18);border-radius:100px;padding:5px 12px}.badge-dot{width:6px;height:6px;border-radius:50%;background:var(--green);animation:pulse 2s ease-in-out infinite}@keyframes pulse{0%,to{opacity:1}50%{opacity:.4}}.badge-text{font-family:var(--font-mono);font-size:11px;color:var(--green);font-weight:500;letter-spacing:.06em}.page-date{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary)}.section{margin-bottom:48px}.section-title-row{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.section-left{display:flex;align-items:center;gap:10px}.section-icon{width:30px;height:30px;border-radius:7px;display:flex;align-items:center;justify-content:center;font-size:14px;border:1px solid var(--border);background:var(--bg-elevated)}.section-title{font-family:var(--font-display);font-size:17px;font-weight:700;color:var(--text);letter-spacing:-.02em}.section-count{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);background:var(--bg-elevated);border:1px solid var(--border);border-radius:100px;padding:2px 8px}.see-all{font-size:13px;font-weight:500;color:var(--green);cursor:pointer;transition:opacity .2s ease;background:none;border:none;display:flex;align-items:center;gap:4px}.see-all:hover{opacity:.7}.personal-section{margin-bottom:48px}.personal-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:16px}.personal-greeting{font-family:var(--font-display);font-size:20px;font-weight:700;color:var(--text);letter-spacing:-.02em}.greeting-name{color:var(--green)}.btn-portfolio-link{background:none;border:1.5px solid var(--border);border-radius:8px;padding:7px 14px;font-family:var(--font-body);font-size:13px;font-weight:500;color:var(--text-secondary);display:flex;align-items:center;gap:5px;transition:background .2s ease,border-color .2s ease,color .2s ease}.btn-portfolio-link:hover{background:var(--bg-elevated);border-color:var(--text-tertiary);color:var(--text)}.personal-summary-row{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin-bottom:16px}.personal-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;padding:20px 24px;box-shadow:var(--shadow-sm)}.personal-card.highlight{border-color:#05966938;background:linear-gradient(135deg,#fff,#f0fdf8);box-shadow:0 2px 12px #05966914}.pc-label{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.09em;text-transform:uppercase;color:var(--text-secondary);margin-bottom:8px}.pc-value{font-family:var(--font-display);font-size:30px;font-weight:800;color:var(--text);letter-spacing:-.03em;line-height:1;margin-bottom:6px}.pc-value.green{color:var(--green)}.pc-value.red{color:var(--red)}.pc-sub{font-size:12px;color:var(--text-secondary)}.pc-sub.green{color:var(--green)}.pc-sub.red{color:var(--red)}.personal-mid-row{display:grid;grid-template-columns:1fr 300px;gap:12px;margin-bottom:16px}.chart-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}.chart-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 18px 12px;border-bottom:1px solid var(--border-subtle)}.chart-panel-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.02em}.chart-tab-group{display:flex;gap:2px;background:var(--bg);border:1px solid var(--border);border-radius:7px;padding:2px}.chart-tab{background:transparent;border:none;border-radius:5px;padding:4px 10px;font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text-secondary);transition:background .15s ease,color .15s ease}.chart-tab.active{background:var(--bg-elevated);color:var(--text);box-shadow:var(--shadow-sm)}.chart-tab:hover:not(.active){color:var(--text)}.chart-body{padding:12px 18px 4px;background:#fafbfd}.chart-svg{width:100%;height:110px;display:block}.chart-footer{display:flex;align-items:center;justify-content:space-between;padding:8px 18px 14px;background:#fafbfd}.chart-start,.chart-end{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.chart-diff{font-family:var(--font-mono);font-size:12px;font-weight:700;padding:2px 9px;border-radius:5px}.chart-diff.up{color:var(--green);background:var(--green-dim)}.chart-diff.down{color:var(--red);background:var(--red-dim)}.trades-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);display:flex;flex-direction:column}.trades-panel-header{display:flex;align-items:center;justify-content:space-between;padding:14px 16px 12px;border-bottom:1px solid var(--border-subtle)}.trades-panel-title{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.02em}.trades-count-badge{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary);background:var(--bg);border:1px solid var(--border);border-radius:100px;padding:2px 8px}.trades-list{flex:1;display:flex;flex-direction:column}.trade-item{display:flex;align-items:center;gap:10px;padding:12px 16px;border-bottom:1px solid var(--border-subtle);transition:background .15s ease}.trade-item:hover{background:var(--bg)}.trade-left{display:flex;align-items:center;gap:6px;flex-shrink:0}.trade-time{font-family:var(--font-mono);font-size:10px;color:var(--text-tertiary);width:34px}.trade-type-badge{font-family:var(--font-mono);font-size:10px;font-weight:700;padding:2px 6px;border-radius:4px}.trade-type-badge.buy{color:var(--green);background:var(--green-dim)}.trade-type-badge.sell{color:var(--red);background:var(--red-dim)}.trade-mid{flex:1}.trade-symbol{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--text);display:block;letter-spacing:-.01em}.trade-detail{font-family:var(--font-mono);font-size:10px;color:var(--text-secondary);display:block;margin-top:1px}.trade-total{font-family:var(--font-mono);font-size:12px;font-weight:600;flex-shrink:0}.trade-total.green{color:var(--green)}.trade-total.red{color:var(--red)}.trades-summary{margin-top:auto;display:flex;align-items:center;justify-content:space-between;padding:12px 16px;background:var(--bg);border-top:1px solid var(--border)}.ts-label{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary)}.ts-value{font-family:var(--font-mono);font-size:13px;font-weight:700}.ts-value.green{color:var(--green)}.ts-value.red{color:var(--red)}.quick-holdings{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm);margin-bottom:0}.qh-header{display:grid;grid-template-columns:1fr 80px 100px 100px 110px;gap:12px;padding:11px 18px;border-bottom:1px solid var(--border);background:var(--bg)}.qh-th{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.qh-th.right{text-align:right}.qh-row{display:grid;grid-template-columns:1fr 80px 100px 100px 110px;gap:12px;padding:13px 18px;border-bottom:1px solid var(--border-subtle);align-items:center;cursor:pointer;transition:background .15s ease}.qh-row:last-child{border-bottom:none}.qh-row:hover{background:var(--bg)}.qh-stock{display:flex;align-items:center;gap:10px}.qh-avatar{width:32px;height:32px;border-radius:7px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:8px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.qh-symbol{font-family:var(--font-display);font-size:13px;font-weight:700;color:var(--text);letter-spacing:-.01em}.qh-name{font-size:11px;color:var(--text-secondary);margin-top:1px}.qh-td{font-family:var(--font-mono);font-size:12px;color:var(--text);font-weight:500;text-align:right}.qh-td.secondary{color:var(--text-secondary);font-weight:400}.qh-pnl{text-align:right}.qh-pnl-val{font-family:var(--font-mono);font-size:12px;font-weight:600;display:block}.qh-pnl-val.up{color:var(--green)}.qh-pnl-val.down{color:var(--red)}.qh-pnl-pct{font-family:var(--font-mono);font-size:10px;display:block;margin-top:1px}.qh-pnl-pct.up{color:var(--green)}.qh-pnl-pct.down{color:var(--red)}.section-divider{display:flex;align-items:center;gap:16px;margin-bottom:40px}.divider-line{flex:1;height:1px;background:var(--border)}.divider-label{font-family:var(--font-mono);font-size:11px;font-weight:500;letter-spacing:.1em;text-transform:uppercase;color:var(--text-tertiary);white-space:nowrap}.indices-grid{display:grid;grid-template-columns:repeat(6,1fr);gap:10px}.index-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:12px;padding:16px 18px;box-shadow:var(--shadow-sm);cursor:pointer;transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease}.index-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px)}.index-card.up:hover{border-color:#05966933}.index-card.down:hover{border-color:#dc262626}.index-name{font-family:var(--font-mono);font-size:11px;font-weight:600;letter-spacing:.06em;color:var(--text-secondary);margin-bottom:8px}.index-value{font-family:var(--font-display);font-size:18px;font-weight:800;color:var(--text);letter-spacing:-.02em;line-height:1;margin-bottom:6px}.index-bottom{display:flex;align-items:center;justify-content:space-between}.index-change{font-family:var(--font-mono);font-size:11px;font-weight:500;color:var(--text-tertiary)}.index-pct{font-family:var(--font-mono);font-size:12px;font-weight:700;padding:2px 7px;border-radius:4px}.index-pct.up{color:var(--green);background:var(--green-dim)}.index-pct.down{color:var(--red);background:var(--red-dim)}.volume-list{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}.volume-header{display:grid;grid-template-columns:32px 1fr 120px 110px 110px;gap:12px;padding:11px 20px;border-bottom:1px solid var(--border);background:var(--bg)}.vol-header-cell{font-family:var(--font-mono);font-size:10px;font-weight:500;letter-spacing:.08em;text-transform:uppercase;color:var(--text-tertiary)}.vol-header-cell.right{text-align:right}.volume-item{display:grid;grid-template-columns:32px 1fr 120px 110px 110px;gap:12px;padding:13px 20px;align-items:center;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background .15s ease}.volume-item:last-child{border-bottom:none}.volume-item:hover{background:var(--bg)}.vol-rank{font-family:var(--font-mono);font-size:12px;color:var(--text-tertiary);font-weight:500}.vol-identity{display:flex;align-items:center;gap:10px}.vol-avatar{width:32px;height:32px;border-radius:7px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:8px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.vol-symbol{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}.vol-name{font-size:11px;color:var(--text-secondary);margin-top:1px}.vol-price{font-family:var(--font-mono);font-size:13px;color:var(--text);font-weight:500;text-align:right}.vol-change{font-family:var(--font-mono);font-size:12px;font-weight:600;text-align:right;padding:2px 7px;border-radius:4px;justify-self:end}.vol-change.up{color:var(--green);background:var(--green-dim)}.vol-change.down{color:var(--red);background:var(--red-dim)}.vol-volume{font-family:var(--font-mono);font-size:12px;color:var(--text-secondary);text-align:right}.movers-row{display:grid;grid-template-columns:1fr 1fr;gap:20px}.movers-panel{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}.movers-panel-header{display:flex;align-items:center;gap:10px;padding:14px 20px;border-bottom:1px solid var(--border)}.panel-icon{font-size:15px}.panel-title{font-family:var(--font-display);font-size:15px;font-weight:700;color:var(--text);letter-spacing:-.02em}.panel-subtitle{font-size:12px;color:var(--text-secondary);margin-left:auto}.mover-item{display:flex;align-items:center;justify-content:space-between;padding:12px 20px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background .15s ease}.mover-item:last-child{border-bottom:none}.mover-item:hover{background:var(--bg)}.mover-identity{display:flex;align-items:center;gap:10px}.mover-avatar{width:32px;height:32px;border-radius:7px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:8px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.mover-avatar.up-bg{background:var(--green-dim);border-color:#05966926;color:var(--green)}.mover-avatar.down-bg{background:var(--red-dim);border-color:#dc262626;color:var(--red)}.mover-symbol{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}.mover-name{font-size:11px;color:var(--text-secondary);margin-top:1px}.mover-right{text-align:right}.mover-price{font-family:var(--font-mono);font-size:13px;color:var(--text);font-weight:500}.mover-change{font-family:var(--font-mono);font-size:12px;font-weight:700;margin-top:2px;padding:2px 6px;border-radius:4px;display:inline-block}.mover-change.up{color:var(--green);background:var(--green-dim)}.mover-change.down{color:var(--red);background:var(--red-dim)}.recommended-grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px}.stock-card{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;padding:18px 20px;box-shadow:var(--shadow-sm);transition:box-shadow .2s ease,transform .2s ease,border-color .2s ease;cursor:pointer}.stock-card:hover{box-shadow:var(--shadow-md);transform:translateY(-2px);border-color:#05966933}.card-top{display:flex;align-items:flex-start;justify-content:space-between;margin-bottom:14px}.stock-identity{display:flex;align-items:center;gap:9px}.stock-avatar{width:34px;height:34px;border-radius:8px;background:var(--bg);border:1px solid var(--border);display:flex;align-items:center;justify-content:center;font-family:var(--font-mono);font-size:8px;font-weight:600;color:var(--text-secondary);flex-shrink:0}.stock-symbol{font-family:var(--font-display);font-size:14px;font-weight:700;color:var(--text);letter-spacing:-.01em}.stock-company{font-size:11px;color:var(--text-secondary);margin-top:1px;white-space:nowrap;overflow:hidden;text-overflow:ellipsis;max-width:110px}.change-badge{font-family:var(--font-mono);font-size:11px;font-weight:600;padding:3px 7px;border-radius:5px;flex-shrink:0}.change-badge.up{color:var(--green);background:var(--green-dim)}.change-badge.down{color:var(--red);background:var(--red-dim)}.card-price{font-family:var(--font-mono);font-size:20px;font-weight:500;color:var(--text);letter-spacing:-.02em;margin-bottom:3px}.card-sector{font-size:11px;color:var(--text-tertiary);margin-bottom:14px}.btn-card-buy{width:100%;background:var(--green);color:#fff;border:none;border-radius:8px;padding:9px;font-family:var(--font-body);font-size:13px;font-weight:600;transition:opacity .2s ease}.btn-card-buy:hover{opacity:.85}.news-list{background:var(--bg-elevated);border:1px solid var(--border);border-radius:14px;overflow:hidden;box-shadow:var(--shadow-sm)}.news-item{display:flex;align-items:flex-start;gap:16px;padding:16px 20px;border-bottom:1px solid var(--border-subtle);cursor:pointer;transition:background .15s ease}.news-item:last-child{border-bottom:none}.news-item:hover{background:var(--bg)}.news-tag{font-family:var(--font-mono);font-size:10px;font-weight:600;letter-spacing:.06em;text-transform:uppercase;color:var(--blue);background:var(--blue-dim);border-radius:4px;padding:3px 7px;white-space:nowrap;flex-shrink:0;margin-top:2px}.news-body{flex:1}.news-title{font-size:14px;font-weight:600;color:var(--text);line-height:1.5;margin-bottom:5px}.news-meta{display:flex;align-items:center;gap:8px}.news-source{font-family:var(--font-mono);font-size:11px;color:var(--text-secondary);font-weight:500}.news-sep{width:3px;height:3px;border-radius:50%;background:var(--text-tertiary)}.news-time{font-family:var(--font-mono);font-size:11px;color:var(--text-tertiary)}.news-arrow{color:var(--text-tertiary);font-size:14px;flex-shrink:0;margin-top:2px;transition:color .2s ease}.news-item:hover .news-arrow{color:var(--text)}
