:root{--bg-base:#f3f4f6;--bg-panel:#fff;--border-color:#e5e7eb;--text-main:#111827;--text-muted:#6b7280;--color-up:#ef4444;--color-down:#10b981;--color-primary:#3b82f6;--font-family:"PingFang TC", "Microsoft JhengHei", "Inter", sans-serif;--panel-radius:8px}*{box-sizing:border-box;margin:0;padding:0}body{font-family:var(--font-family);background-color:var(--bg-base);color:var(--text-main);flex-direction:column;height:100vh;font-size:14px;display:flex;overflow:hidden}#root{flex-direction:column;height:100vh;display:flex;overflow:hidden}.app-shell{flex-direction:column;flex:1;min-height:0;display:flex;overflow:hidden}.top-navbar{background-color:var(--bg-panel);border-bottom:1px solid var(--border-color);z-index:10;flex-shrink:0;justify-content:space-between;align-items:center;height:56px;padding:0 16px;display:flex;box-shadow:0 1px 3px #0000000d}.ticker-input-wrapper{border:1px solid var(--border-color);background:#fff;border-radius:6px;align-items:center;padding:4px 12px;display:flex;box-shadow:inset 0 1px 2px #0000000d}.navbar-left{flex-wrap:wrap;align-items:center;gap:12px;min-width:0;display:flex}.navbar-stock-name{color:var(--text-main);font-size:20px;font-weight:700}.navbar-divider{background:var(--border-color);width:1px;height:20px;margin:0 4px}.navbar-date{color:var(--text-muted);font-size:15px;font-weight:700}.navbar-date-input{border:1px solid var(--border-color);height:34px;color:var(--text-muted);background:#fff;border-radius:8px;outline:none;padding:6px 10px;font-size:14px;font-weight:700}.navbar-ticks-pill{color:var(--color-primary);background:#3b82f614;border-radius:10px;padding:2px 8px;font-size:12px}.ticker-input-wrapper input{width:120px;color:var(--color-primary);letter-spacing:1px;background:0 0;border:none;outline:none;font-size:18px;font-weight:700}.ticker-input-wrapper input::placeholder{color:#d1d5db;font-weight:400}.replay-controls{background-color:var(--bg-base);border:1px solid var(--border-color);border-radius:24px;align-items:center;gap:12px;padding:6px 18px;display:flex}.replay-label{color:var(--text-muted);font-size:13px}.replay-time{text-align:center;min-width:74px;font-size:17px;font-weight:700}.replay-slider{width:230px;accent-color:var(--color-primary)}.replay-controls button{color:var(--text-main);cursor:pointer;background:0 0;border:none;justify-content:center;align-items:center;font-size:16px;display:flex}.replay-controls button:hover{color:var(--color-primary)}.replay-step-btn{min-width:24px}.play-btn{color:var(--color-primary)!important;font-size:20px!important}.speed-selector{border:1px solid var(--border-color);color:var(--text-main);background:#fff;border-radius:4px;height:32px;padding:3px 8px}.navbar-right{align-items:center;gap:10px;display:flex}.api-usage-box{text-align:right;background:#00000008;border-radius:6px;padding:3px 8px;font-size:10px;line-height:1.35}.settings-btn{border:1px solid var(--border-color);cursor:pointer;background:#fff;border-radius:6px;align-items:center;gap:6px;padding:7px 14px;font-weight:700;display:flex}.settings-btn-inline,.api-usage-inline{display:none}.toast-stack{z-index:220;pointer-events:none;flex-direction:column;gap:10px;width:min(360px,100vw - 24px);display:flex;position:fixed;top:70px;right:16px}.toast-card{color:var(--text-main);pointer-events:auto;background:#fffffff7;border:1px solid #10b9813d;border-radius:14px;align-items:center;gap:10px;padding:12px 14px;display:flex;box-shadow:0 12px 26px #0f172a1f}.toast-success{border-left:4px solid #10b981}.toast-info{border-left:4px solid #3b82f6}.toast-icon{color:#059669;background:#10b9811f;border-radius:999px;flex:none;justify-content:center;align-items:center;width:22px;height:22px;font-size:13px;font-weight:800;display:inline-flex}.toast-message{flex:auto;min-width:0;font-size:14px;font-weight:700;line-height:1.45}.toast-info .toast-icon{color:#2563eb;background:#3b82f61f}.toast-close{color:var(--text-muted);cursor:pointer;background:0 0;border:none;padding:0;font-size:20px;line-height:1}@media (width>=1101px){.main-workspace>.sidebar-section{align-self:stretch;overflow:hidden}.replay-controls{border-radius:20px;gap:10px;padding:4px 14px}.replay-time{min-width:68px;font-size:15px}.replay-slider{width:200px}.replay-controls button{font-size:15px}.play-btn{font-size:18px!important}.speed-selector{min-width:72px;height:30px;padding:2px 8px}.bottom-panel{height:118px}.main-workspace>.sidebar-section .panel-header{padding:6px 10px;font-size:12px}.main-workspace>.sidebar-section .ob-table th{padding:4px 5px;font-size:11px}.main-workspace>.sidebar-section .ob-table td{padding:3px 5px;font-size:13px}.main-workspace>.sidebar-section .power-bar-container{padding:5px 10px}.main-workspace>.sidebar-section .power-labels{margin-bottom:2px;font-size:11px}.main-workspace>.sidebar-section .trading-panel{padding:7px 9px 8px}.main-workspace>.sidebar-section .broker-order-topbar{gap:5px;margin-bottom:3px}.main-workspace>.sidebar-section .broker-pill{min-height:30px;font-size:11px}.main-workspace>.sidebar-section .broker-trade-modes{margin-bottom:5px;padding:5px}.main-workspace>.sidebar-section .trade-mode-chip{padding:5px 6px;font-size:11px}.main-workspace>.sidebar-section .trade-mode-hint{display:none}.main-workspace>.sidebar-section .broker-stepper-grid{gap:5px;margin-bottom:1px}.main-workspace>.sidebar-section .broker-stepper-card{gap:3px}.main-workspace>.sidebar-section .broker-stepper-label{font-size:10px}.main-workspace>.sidebar-section .broker-stepper-control{grid-template-columns:28px minmax(0,1fr) 28px;min-height:34px}.main-workspace>.sidebar-section .broker-stepper-btn{font-size:15px}.main-workspace>.sidebar-section .broker-stepper-control input{padding:2px 4px;font-size:16px}.main-workspace>.sidebar-section .broker-order-note{margin-bottom:3px;font-size:9px;line-height:1.25}.main-workspace>.sidebar-section .trade-buttons{gap:6px}.main-workspace>.sidebar-section .btn{min-height:36px;padding:6px 8px;font-size:13px}}@media (width>=641px){.settings-btn-inline,.api-usage-inline{display:none!important}}.main-workspace{background-color:var(--bg-base);flex:1;gap:16px;padding:16px;display:flex;overflow:hidden}.panel{background-color:var(--bg-panel);border-radius:var(--panel-radius);border:1px solid var(--border-color);flex-direction:column;display:flex;overflow:hidden;box-shadow:0 2px 8px #0000000a}.chart-section{flex:1 1 0;min-width:0}.ticks-section{flex-shrink:0;width:clamp(320px,25vw,380px)}.sidebar-section{flex-direction:column;flex-shrink:0;gap:12px;width:clamp(300px,24vw,340px);display:flex;overflow:hidden}.main-workspace>.sidebar-section{align-self:stretch;max-height:100%;overflow:hidden}.sidebar-book-shell{flex-shrink:0;overflow:hidden}.sidebar-trading-shell{flex-direction:column;flex:1;display:flex;overflow:hidden}.sidebar-trading-shell>.panel{flex-direction:column;flex:1;display:flex}.sidebar-trading-shell .trading-panel{border-top:none;flex-direction:column;flex:1;justify-content:space-between;display:flex}.bottom-panel{flex-direction:column;height:130px;min-height:0;margin:0 16px 16px;display:flex}.bottom-panel-body{flex:auto;min-height:0;overflow:hidden}.mobile-layout{background:var(--bg-base);flex-direction:column;flex:1;gap:12px;min-height:0;padding:12px;display:flex;overflow:hidden}.mobile-switcher{flex-shrink:0;grid-template-columns:repeat(3,minmax(0,1fr));gap:8px;display:grid}.mobile-switch-btn{border:1px solid var(--border-color);color:var(--text-muted);cursor:pointer;background:#fff;border-radius:10px;padding:10px 8px;font-size:13px;font-weight:700;transition:all .15s}.mobile-switch-btn.active{color:var(--color-primary);background:#3b82f614;border-color:#3b82f647;box-shadow:inset 0 0 0 1px #3b82f614}.mobile-stage{flex:1;min-height:0;display:flex;overflow:hidden}.mobile-stage-account{-webkit-overflow-scrolling:touch;overflow-y:auto}.mobile-market-stack,.mobile-chart-stack{flex-direction:column;flex:1;align-items:stretch;gap:8px;min-height:0;padding-bottom:4px;display:flex;overflow:hidden auto}.mobile-chart-detail-shell{flex:none;min-height:320px;overflow:hidden}.mobile-chart-detail-header{align-items:center;gap:10px}.mobile-chart-detail-tabs{background:#3b82f612;border-radius:12px;align-items:center;gap:6px;padding:4px;display:inline-flex}.mobile-chart-detail-tab{color:var(--text-muted);cursor:pointer;background:0 0;border:none;border-radius:10px;min-width:58px;padding:7px 12px;font-size:12px;font-weight:700;transition:background .15s,color .15s,box-shadow .15s}.mobile-chart-detail-tab.active{color:var(--color-primary);background:#fff;box-shadow:0 1px 3px #0f172a14}.mobile-chart-detail-summary{margin-left:auto;font-size:12px;font-weight:500}.mobile-chart-detail-body{flex-direction:column;min-height:260px;max-height:min(46vh,420px);display:flex;overflow:hidden}.tick-panel-embedded{flex:1;min-height:0;display:flex}.tick-data-container-embedded{flex:1}.mobile-chart-stack>.panel,.mobile-market-stack>.panel{width:100%;height:auto;max-height:none;margin:0;overflow:visible}.mobile-stage>.panel{flex:1;min-height:0}.panel-header{color:var(--text-muted);border-bottom:1px solid var(--border-color);background:#f9fafb;flex-shrink:0;justify-content:space-between;padding:8px 12px;font-size:13px;font-weight:700;display:flex}.panel-header-actions{align-items:center;gap:6px;display:flex}.tick-expand-btn{width:24px;height:24px;color:var(--text-muted);cursor:pointer;background:#fff;border:1px solid #94a3b859;border-radius:999px;justify-content:center;align-items:center;transition:border-color .16s,color .16s,background .16s;display:inline-flex}.tick-expand-btn:hover{color:var(--color-primary);background:#3b82f60a;border-color:#3b82f659}.tick-expand-arrow{font-size:12px;line-height:1;transition:transform .16s;transform:translateY(1px)}.tick-expand-arrow.expanded{transform:rotate(180deg)}.chart-header{border-bottom:1px solid var(--border-color);background:var(--bg-panel);flex-wrap:wrap;flex-shrink:0;align-items:center;gap:20px;padding:12px 20px;display:flex}.chart-header .item{flex-direction:column;display:flex}.chart-header .item span:first-child{color:var(--text-muted);margin-bottom:4px;font-size:12px}.price-big{color:var(--color-up);font-size:24px;font-weight:700}.val-up{color:var(--color-up)}.val-down{color:var(--color-down)}.val-flat{color:var(--text-muted)}.chart-container{color:#ccc;background:#fafafa;border-radius:0 0 8px 8px;flex:1;justify-content:center;align-items:center;font-size:24px;display:flex}.chart-panel{background:#1e2740;border-color:#5b6c8f4d;box-shadow:0 18px 34px #080c183d}.chart-hero{background:linear-gradient(#ffffff08,#fff0),#1e2740;border-bottom:1px solid #8a99bc24;flex-direction:column;gap:10px;padding:10px 18px 12px;display:flex}.chart-hero-topbar{justify-content:space-between;align-items:center;gap:12px;display:flex}.chart-hero-tags{flex-wrap:wrap;align-items:center;gap:6px;min-width:0;display:flex}.chart-market-chip{color:#eaeffadb;letter-spacing:.03em;background:#ffffff0d;border:1px solid #d7b26314;border-radius:4px;justify-content:center;align-items:center;min-width:34px;height:24px;padding:0 9px;font-size:13px;font-weight:700;display:inline-flex}.chart-market-chip.active{color:#f2d59a;background:linear-gradient(#84612cf2,#614720f2);border-color:#e3bb6929}.chart-market-chip-trade{color:#d9a85f;background:#78582b2e;border-color:#d7b26314;min-width:auto}.chart-index-board{flex-wrap:wrap;justify-content:flex-end;align-items:center;gap:10px;display:flex}.chart-index-card{flex-direction:column;align-items:flex-end;gap:2px;min-width:116px;padding:4px 0;display:flex}.chart-index-label{color:#c6d0e49e;letter-spacing:.08em;font-size:11px;font-weight:600}.chart-index-values{align-items:baseline;gap:8px;display:flex}.chart-index-main{color:#f4f7ff;font-size:17px;font-weight:700;line-height:1}.chart-index-change{color:#d2dbefad;font-size:12px;font-weight:700}.chart-index-main.up,.chart-index-change.up{color:#ff645f}.chart-index-main.down,.chart-index-change.down{color:#76d363}.chart-index-main.neutral,.chart-index-change.neutral{color:#f0f5ffd1}.chart-hero-name-block{justify-content:flex-start;align-items:center;display:flex}.chart-hero-price{flex-direction:column;gap:6px;min-width:0;display:flex}.chart-hero-main{letter-spacing:.01em;font-size:46px;font-weight:800;line-height:.95}.chart-hero-change{font-size:15px;font-weight:700}.chart-hero-main.up,.chart-hero-change.up{color:#ff645f}.chart-hero-main.down,.chart-hero-change.down{color:#1fd1d0}.chart-hero-main.neutral,.chart-hero-change.neutral{color:#f4f7ff}.chart-hero-title-wrap{flex-direction:column;align-items:flex-start;gap:3px;min-width:0;display:flex}.chart-hero-title{color:#f6f8ff;letter-spacing:.02em;font-size:22px;font-weight:800;line-height:1.1}.chart-hero-subtitle{color:#cbd4e8b8;letter-spacing:.08em;font-size:12px;font-weight:600}.chart-hero-main-grid{grid-template-columns:minmax(230px,.85fr) minmax(260px,1fr);align-items:end;gap:18px;display:grid}.chart-hero-summary{flex-direction:column;gap:12px;min-width:0;display:flex}.chart-hero-metrics{grid-template-columns:repeat(3,minmax(92px,1fr));align-content:end;gap:10px 18px;display:grid}.metric-pair{align-items:baseline;gap:10px;min-width:0;display:flex}.metric-label{color:#c6d0e4a8;min-width:34px;font-size:14px;font-weight:500}.metric-value{color:#f5f7ff;letter-spacing:.01em;font-size:16px;font-weight:700}.metric-value.up{color:#ff645f}.metric-value.down{color:#76d363}.metric-value.neutral{color:#f4f7ff}.chart-canvas-shell{background:#1e2740;flex:1;min-height:0;position:relative}.chart-canvas{width:100%;height:100%}.chart-mini-stats{color:#c9d2e7b8;background:#1e2740;border-bottom:1px solid #8a99bc24;flex-shrink:0;justify-content:center;align-items:center;gap:10px;height:42px;padding:0 16px;font-size:13px;display:flex}.chart-mini-stats .label{font-weight:500}.chart-mini-stats .value{color:#f3f7ff;letter-spacing:.02em;min-width:42px;font-weight:700}.chart-mini-stats .price{color:#ff6260}.chart-mini-stats .price.down{color:#20d0cf}.chart-mini-stats .price.neutral{color:#f3f7ff}.chart-mini-stats .avg{color:#ac8cff}.chart-mini-stats .volume{color:#2a89ff}.chart-line-legend{color:#e1e8f7d6;align-items:center;gap:12px;margin-left:auto;font-size:12px;font-weight:600;display:inline-flex}.chart-line-legend-item{white-space:nowrap;align-items:center;gap:6px;display:inline-flex}.chart-line-swatch{border-top:2px solid;border-radius:999px;width:18px;height:0;display:inline-block}.chart-line-swatch.price{color:#ff5b57}.chart-line-swatch.avg{color:#a789ff}.tick-data-container{overflow-anchor:none;background:#fff;flex:1;min-height:0;overflow-y:auto}.tick-table{border-collapse:collapse;text-align:center;table-layout:fixed;width:100%}.tick-table th{color:var(--text-muted);border-bottom:1px solid var(--border-color);z-index:1;white-space:nowrap;background:#f9fafb;padding:10px 4px;font-size:13px;font-weight:400;position:sticky;top:0}.tick-table td{white-space:nowrap;border-bottom:1px solid #f3f4f6;padding:8px 4px;font-size:15px}.tick-table th:first-child,.tick-table td:first-child{width:26%}.tick-table th:nth-child(2),.tick-table td:nth-child(2),.tick-table th:nth-child(3),.tick-table td:nth-child(3),.tick-table th:nth-child(4),.tick-table td:nth-child(4){width:21%}.tick-table th:nth-child(5),.tick-table td:nth-child(5){width:11%}.tick-time{color:var(--text-muted);font-size:13px}.order-book-container{flex-direction:column;display:flex}.order-book-empty{border-bottom:1px solid var(--border-color);background:linear-gradient(#fff 0%,#f8fafc 100%);flex-direction:column;gap:8px;padding:16px 14px;display:flex}.order-book-empty-title{color:var(--text-main);font-size:14px;font-weight:700}.order-book-empty-text{color:var(--text-muted);font-size:12px;line-height:1.6}.ob-table{border-collapse:collapse;width:100%}.ob-table th{color:var(--text-muted);border-bottom:1px solid var(--border-color);padding:6px;font-size:12px;font-weight:400}.ob-table td{padding:4px 6px;font-size:15px;font-weight:700}.ob-table tr{border-bottom:1px solid #f3f4f6}.ob-buy-vol{text-align:center;width:20%;color:var(--text-main);font-weight:500!important}.ob-buy-px{text-align:center;width:30%;color:var(--color-up);border-right:1px solid var(--border-color);background:#ef44440d}.ob-sell-px{text-align:center;width:30%;color:var(--color-down);background:#10b9810d}.ob-sell-vol{text-align:center;width:20%;color:var(--text-main);font-weight:500!important}.power-bar-container{border-bottom:1px solid var(--border-color);background:#fff;padding:6px 10px}.power-labels{color:var(--text-muted);justify-content:space-between;margin-bottom:3px;font-size:11px;display:flex}.power-bar{border-radius:3px;height:6px;display:flex;overflow:hidden}.power-buy{background:var(--color-up)}.power-sell{background:var(--color-down)}.trading-panel{border-top:1px solid var(--border-color);background:#f9fafb;flex:none;padding:8px 10px 10px}.order-book-container{flex:none;min-height:0}.broker-order-topbar{grid-template-columns:minmax(0,1.4fr) repeat(2,minmax(0,.7fr));gap:6px;margin-bottom:4px;display:grid}.broker-pill{border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;background:#fff;border-radius:4px;min-height:32px;font-size:12px;font-weight:800}.broker-pill-fixed{cursor:default;background:#fff;justify-content:center;align-items:center;display:flex}.broker-pill-limit.active{color:#fff;background:#0ea5c6;border-color:#0ea5c6b3}.broker-pill-market.active{color:#fff;background:#f59e0b;border-color:#f59e0bb8}.trade-type-selector{border:1px solid var(--border-color);background:#fff;border-radius:6px;flex-wrap:wrap;justify-content:space-between;gap:6px;margin-bottom:6px;padding:6px 8px;display:flex}.trade-type-selector label{cursor:pointer;align-items:center;gap:6px;font-size:13px;display:flex}.trade-type-day{color:var(--color-primary);font-weight:700}.broker-trade-modes{border-color:var(--border-color);background:#fff;margin-bottom:6px;padding:6px}.trade-mode-chip{border:1px solid var(--border-color);min-width:0;color:var(--text-main);cursor:pointer;background:#fff;border-radius:6px;flex:1;padding:6px 8px;font-size:12px;font-weight:700;transition:all .15s}.broker-trade-modes .trade-mode-chip{border-color:var(--border-color);color:var(--text-muted);background:#fff}.broker-trade-modes .trade-mode-chip.active,.broker-trade-modes .trade-mode-chip.mode-daytrade_short.active{color:#f0fdf4;background:#16a34a;border-color:#22c55ee6;box-shadow:inset 0 0 0 1px #ffffff14}.broker-trade-modes .trade-mode-chip.mode-margin_long.active{color:#fff5f5;background:#ef4444;border-color:#f87171eb}.broker-trade-modes .trade-mode-chip.mode-margin_short.active{color:#f0fdf4;background:#16a34a;border-color:#4ade80e6}.trade-mode-chip.active{border-color:var(--color-primary);color:var(--color-primary);background:#3b82f614;box-shadow:inset 0 0 0 1px #3b82f61a}.trade-mode-chip.mode-daytrade_short{color:#059669;border-color:#10b9812e}.trade-mode-chip.mode-daytrade_short.active{color:#047857;background:#10b9811f;border-color:#10b9816b;box-shadow:inset 0 0 0 1px #10b9811f}.trade-mode-hint{color:var(--text-muted);margin-bottom:4px;font-size:11px;font-weight:600}.broker-stepper-grid{grid-template-columns:1fr .9fr;gap:6px;margin-bottom:2px;display:grid}.broker-stepper-card{flex-direction:column;gap:4px;display:flex}.broker-stepper-label{color:var(--text-muted);font-size:11px;font-weight:700}.broker-stepper-control{grid-template-columns:30px minmax(0,1fr) 30px;align-items:stretch;min-height:36px;display:grid}.broker-stepper-btn{border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;background:#fff;font-size:17px;font-weight:800}.broker-stepper-btn:first-child{border-radius:4px 0 0 4px}.broker-stepper-btn:last-child{border-radius:0 4px 4px 0}.broker-stepper-control input{border:1px solid var(--border-color);width:100%;min-width:0;color:var(--text-main);text-align:center;background:#fff;border-left:none;border-right:none;border-radius:0;outline:none;padding:4px 6px;font-family:Consolas,monospace;font-size:18px;font-weight:800}.broker-stepper-control input:disabled{color:#9ca3af;background:#f3f4f6}.broker-order-note{text-align:right;color:var(--text-muted);margin-bottom:4px;font-size:10px;font-weight:600}.trade-inputs{grid-template-columns:1fr 1fr;gap:12px;margin-bottom:10px;display:grid}.input-group{flex-direction:column;gap:4px;display:flex}.input-group label{color:var(--text-muted);font-size:12px}.input-group input{border:1px solid var(--border-color);text-align:center;box-sizing:border-box;border-radius:4px;outline:none;width:100%;padding:8px;font-family:Consolas,monospace;font-size:18px;font-weight:700}.input-group input:focus{border-color:var(--color-primary)}.trade-buttons{gap:8px;display:flex}.btn{cursor:pointer;color:#fff;border:none;border-radius:6px;flex:1;min-height:40px;padding:7px 8px;font-size:14px;font-weight:700;transition:all .1s}.btn:active{transform:scale(.98)}.btn-buy{background:var(--color-up)}.btn-buy:hover{background:#dc2626}.btn-sell{background:var(--color-down)}.btn-sell:hover{background:#059669}.bottom-tabs{border-bottom:1px solid var(--border-color);background:#f9fafb;flex-shrink:0;padding:0 16px;display:flex}.bottom-tab{color:var(--text-muted);cursor:pointer;border-top:3px solid #0000;padding:12px 20px;font-weight:700}.bottom-tab.active{color:var(--color-primary);background:var(--bg-panel);border-top:3px solid var(--color-primary)}.portfolio-area{flex:1;display:flex;overflow:hidden}.summary-stats{border-right:1px solid var(--border-color);flex-direction:column;flex-shrink:0;justify-content:flex-start;gap:8px;width:260px;padding:12px 16px;display:flex;overflow-y:auto}.stat-box{flex-direction:column;gap:4px;display:flex}.stat-box .lbl{color:var(--text-muted);font-size:13px}.stat-box .val{font-size:22px;font-weight:700}.table-area{flex:1;padding:8px 16px;overflow-y:auto}.data-table{border-collapse:collapse;width:100%}.data-table th{text-align:left;color:var(--text-muted);border-bottom:1px solid var(--border-color);padding:8px 10px;font-size:13px;font-weight:400}.data-table td{border-bottom:1px solid var(--border-color);padding:10px;font-size:14px}.action-btn{border:1px solid var(--border-color);color:var(--text-main);cursor:pointer;background:#fff;border-radius:4px;padding:4px 12px;font-size:12px;font-weight:700;transition:all .2s}.action-btn:hover{background:#f3f4f6}.mobile-portfolio-stack{flex-direction:column;flex:auto;gap:10px;min-height:0;padding:10px;display:flex;overflow:hidden}.mobile-summary-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px;display:grid}.mobile-summary-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;flex-direction:column;gap:6px;padding:14px 14px 12px;display:flex}.mobile-summary-card.compact{padding:12px 14px}.mobile-summary-card .lbl{color:var(--text-muted);font-size:12px;font-weight:700}.mobile-summary-card .val{font-size:18px;font-weight:800}.mobile-summary-card .val.neutral{color:var(--text-main)}.mobile-summary-card .hint{color:var(--text-muted);font-size:10px;line-height:1.35}.mobile-record-list{-webkit-overflow-scrolling:touch;flex-direction:column;flex:auto;gap:10px;min-height:0;padding-bottom:8px;display:flex;overflow-y:auto}.mobile-record-card,.mobile-empty-card{border:1px solid var(--border-color);background:#fff;border-radius:12px;padding:12px 14px}.mobile-empty-card{color:var(--text-muted);text-align:center;padding:18px 14px;font-weight:600}.mobile-record-head{justify-content:space-between;align-items:flex-start;gap:10px;margin-bottom:10px;display:flex}.mobile-record-title{color:var(--text-main);font-size:15px;font-weight:800}.mobile-record-subtitle{color:var(--text-muted);margin-top:2px;font-size:11px;font-weight:600}.mobile-record-grid{grid-template-columns:repeat(2,minmax(0,1fr));gap:8px 12px;display:grid}.mobile-record-grid>div{flex-direction:column;gap:3px;min-width:0;display:flex}.mobile-record-grid .label{color:var(--text-muted);font-size:11px;font-weight:700}.mobile-record-grid .value{color:var(--text-main);word-break:break-word;font-size:14px;font-weight:700}.mobile-action-btn{width:100%;min-height:36px;margin-top:10px}.mobile-order-edit-row{grid-template-columns:minmax(0,1fr) auto;align-items:end;gap:10px;margin-top:12px;display:grid}.mobile-order-edit-field{flex-direction:column;gap:5px;min-width:0;display:flex}.mobile-order-edit-field .label{color:var(--text-muted);font-size:11px;font-weight:700}.mobile-order-edit-field input{border:1px solid var(--border-color);width:100%;min-width:0;color:var(--text-main);background:#fff;border-radius:10px;padding:9px 10px;font-size:15px;font-weight:700}.mobile-order-edit-field input:focus{border-color:var(--color-primary);outline:none;box-shadow:0 0 0 2px #3b82f61f}.mobile-edit-confirm-btn{min-width:68px;min-height:42px;color:var(--color-primary);border-color:var(--color-primary);padding:0 14px}.modal-overlay{z-index:100;background:#0006;justify-content:center;align-items:center;display:flex;position:fixed;inset:0}.modal-content{background:#fff;border-radius:12px;width:400px;padding:24px;box-shadow:0 8px 32px #00000026}.modal-content h3{margin-bottom:16px;font-size:18px}.modal-content .form-row{justify-content:space-between;align-items:center;margin-bottom:12px;display:flex}.modal-content .form-row label{color:var(--text-main);font-size:14px}.modal-content .form-row input{border:1px solid var(--border-color);text-align:right;border-radius:4px;width:120px;padding:6px 10px;font-size:14px}.modal-content .modal-btns{gap:10px;margin-top:16px;display:flex}.modal-content .modal-btns button{cursor:pointer;border:none;border-radius:6px;flex:1;padding:10px;font-size:14px;font-weight:700}.modal-content .modal-btns .btn-confirm{background:var(--color-primary);color:#fff}.modal-content .modal-btns .btn-cancel{color:var(--text-main);border:1px solid var(--border-color);background:#f3f4f6}@keyframes tickFlash{0%{background-color:#3b82f626}to{background-color:#0000}}.tick-new{animation:.6s ease-out tickFlash}@media (width<=1100px){.ticks-section,.sidebar-section{width:300px}.top-navbar{flex-wrap:wrap;align-items:stretch;gap:12px;height:auto;padding:12px 16px}.navbar-left,.navbar-right{flex-wrap:wrap;width:100%}.replay-controls{border-radius:18px;flex-wrap:wrap;justify-content:center;gap:12px;width:100%;padding:10px 14px}.replay-slider,.replay-controls input[type=range]{flex:220px;width:min(100%,420px)!important}.chart-section{min-height:520px}.chart-hero{gap:14px}.chart-hero-topbar,.chart-hero-main-grid{grid-template-columns:1fr;gap:12px;display:grid}.chart-index-board{justify-content:flex-start}.chart-index-card{align-items:flex-start;min-width:104px}.chart-hero-main{font-size:40px}.chart-hero-name-block{justify-content:center}.chart-hero-summary{gap:10px}.chart-hero-title-wrap{text-align:center;align-items:center}.chart-hero-metrics{grid-template-columns:repeat(2,minmax(120px,1fr));gap:12px 18px}.metric-pair{justify-content:center}.chart-mini-stats{gap:8px;padding:0 14px;font-size:12px}.chart-mini-stats .value{min-width:42px}}@media (width<=900px){body,#root,.app-shell{height:100vh;min-height:100vh;overflow:hidden}.panel-header{flex-wrap:wrap;gap:8px}.mobile-stage .chart-section,.mobile-stage .ticks-section,.mobile-stage .sidebar-section,.mobile-stage .bottom-panel{flex:auto;width:100%;height:100%;min-height:0;max-height:none;margin:0}.mobile-stage .chart-panel{height:auto;overflow-y:auto}.mobile-stage .chart-section{flex:none;height:auto;min-height:0}.mobile-stage .chart-canvas-shell{flex:none;height:clamp(240px,34vh,320px);min-height:clamp(240px,34vh,320px);max-height:clamp(240px,34vh,320px)}.mobile-stage .ticks-section,.mobile-stage .bottom-panel{overflow:hidden}.mobile-stage .sidebar-section{overflow:visible}.mobile-market-stack .mobile-book-panel{flex:none;height:auto;min-height:300px;overflow:visible}.mobile-chart-detail-shell{height:auto;min-height:340px;overflow:hidden}.mobile-market-stack .mobile-trading-only{flex:none;height:auto;min-height:auto}.mobile-stage .tick-data-container,.mobile-stage .table-area{flex:1;min-height:0;overflow:auto}.mobile-market-stack .mobile-book-panel .order-book-container{flex:none;min-height:0;overflow:visible}.mobile-chart-detail-shell .order-book-container{flex-direction:column;flex:1;min-height:0;display:flex;overflow:auto}.mobile-chart-stack .mobile-stage-panel,.mobile-market-stack .mobile-stage-panel{overflow:visible}.mobile-market-stack>.sidebar-section,.mobile-market-stack>.mobile-trading-only{width:100%;height:auto;max-height:none;margin:0}.mobile-stage .portfolio-area{flex-direction:column;flex:1;min-height:0;overflow:hidden}.mobile-stage .summary-stats{border-right:none;border-bottom:1px solid var(--border-color);flex:none;width:100%;padding:12px;overflow:visible}.mobile-stage .mobile-stage-panel{overflow-y:auto}.mobile-stage .ob-table{min-width:0}.mobile-stage .data-table{min-width:640px}.bottom-tabs{-webkit-overflow-scrolling:touch;padding:0 8px;overflow-x:auto}.bottom-tab{white-space:nowrap;flex:none;padding:12px 14px}.modal-content{width:min(92vw,400px);padding:20px}}@media (width<=1400px){.main-workspace>.sidebar-section .trading-panel{padding:8px 10px 10px}.main-workspace>.sidebar-section .panel-header{padding:6px 10px;font-size:12px}.main-workspace>.sidebar-section .ob-table th{padding:5px;font-size:11px}.main-workspace>.sidebar-section .ob-table td{padding:3px 5px;font-size:13px}.main-workspace>.sidebar-section .power-bar-container{padding:6px 10px}.main-workspace>.sidebar-section .power-labels{margin-bottom:3px;font-size:11px}.main-workspace>.sidebar-section .broker-order-topbar{gap:6px;margin-bottom:4px}.main-workspace>.sidebar-section .broker-pill{min-height:32px;font-size:12px}.main-workspace>.sidebar-section .trade-type-selector{margin-bottom:6px}.main-workspace>.sidebar-section .trade-mode-chip{padding:6px 8px;font-size:12px}.main-workspace>.sidebar-section .trade-mode-hint{margin-bottom:4px;font-size:11px}.main-workspace>.sidebar-section .broker-stepper-grid{gap:6px}.main-workspace>.sidebar-section .broker-stepper-control{grid-template-columns:30px minmax(0,1fr) 30px;min-height:36px}.main-workspace>.sidebar-section .broker-stepper-control input{font-size:18px}.main-workspace>.sidebar-section .broker-order-note{margin-bottom:4px;font-size:10px}.main-workspace>.sidebar-section .btn{min-height:38px;padding:7px 8px;font-size:14px}}@media (width<=640px){.toast-stack{width:auto;inset:auto 12px 92px}.toast-card{border-radius:16px;padding:11px 12px}.toast-message{font-size:13px}.top-navbar{gap:6px;padding:8px 10px}.ticker-input-wrapper{flex:0 0 112px;width:auto;min-width:112px}.ticker-input-wrapper input{width:100%;min-width:0;font-size:15px}.navbar-left{white-space:nowrap;-webkit-overflow-scrolling:touch;flex-wrap:nowrap;padding-bottom:0;overflow:auto hidden;gap:4px!important}.navbar-right{display:none}.navbar-stock-name{flex:none;font-size:14px}.navbar-date-input{flex:none;width:128px;min-width:128px;height:30px;padding:4px 8px;font-size:12px}.replay-controls{border-radius:14px;grid-template-columns:minmax(84px,auto) auto auto auto minmax(60px,70px) 28px;align-items:center;gap:6px;padding:8px;display:grid}.replay-controls button{min-width:24px;min-height:24px;font-size:14px}.replay-label{display:none}.replay-time{text-align:left;white-space:nowrap;min-width:84px;font-size:13px;font-weight:800}.replay-slider{grid-column:1/-1;min-width:0;margin:0;width:100%!important}.replay-controls button.play-btn{font-size:17px!important}.speed-selector{min-width:60px;height:26px;padding:2px 4px;font-size:12px}.api-usage-inline{display:none}.settings-btn-inline{border-radius:6px;justify-content:center;padding:0;font-size:13px;font-weight:700;display:inline-flex;min-width:24px!important;min-height:24px!important}.navbar-stock-name{font-size:13px}.navbar-ticks-pill{display:none}.navbar-divider{height:14px}.mobile-layout{gap:8px;padding:8px}.mobile-switcher{grid-template-columns:repeat(3,minmax(0,1fr))}.mobile-switch-btn{border-radius:16px;min-height:44px;padding:10px 8px}.mobile-stage .chart-section{min-height:auto}.mobile-stage .chart-canvas-shell{flex:none;height:clamp(220px,30vh,280px);min-height:clamp(220px,30vh,280px);max-height:clamp(220px,30vh,280px)}.chart-hero{gap:8px;padding:10px 10px 12px}.chart-hero-topbar{gap:10px}.chart-hero-tags{gap:4px}.chart-market-chip{min-width:30px;height:22px;padding:0 8px;font-size:12px}.chart-market-chip-trade{letter-spacing:.02em;padding:0 7px;font-size:11px}.chart-index-board{justify-content:space-between;gap:6px;width:100%}.chart-index-card{flex:1 1 0;min-width:0}.chart-index-main{font-size:15px}.chart-index-change{font-size:11px}.chart-hero-title{font-size:18px}.chart-hero-subtitle{letter-spacing:.04em;font-size:11px}.chart-hero-main{font-size:34px}.chart-hero-change{font-size:13px}.chart-hero-metrics{grid-template-columns:repeat(2,minmax(0,1fr));gap:10px 12px}.metric-pair{justify-content:flex-start;gap:8px}.metric-label{min-width:28px;font-size:13px}.metric-value{font-size:15px}.chart-mini-stats{flex-wrap:wrap;justify-content:flex-start;row-gap:6px;height:auto;min-height:42px;padding:8px 12px}.chart-line-legend{justify-content:flex-end;width:100%;margin-left:0}.chart-hero-summary{flex-direction:row;justify-content:space-between;align-items:baseline;gap:10px}.chart-hero-name-block{flex:auto;justify-content:flex-start;min-width:0}.chart-hero-title-wrap{text-align:left;flex-flow:row;align-items:baseline;gap:6px;min-width:0}.chart-hero-title{white-space:nowrap;font-size:14px;line-height:1}.chart-hero-subtitle{letter-spacing:.02em;white-space:nowrap;text-overflow:ellipsis;font-size:10px;overflow:hidden}.chart-hero-price{flex-direction:row;flex:none;justify-content:flex-end;align-items:baseline;gap:6px}.chart-hero-main{font-size:24px;line-height:1}.chart-hero-change{white-space:nowrap;font-size:11px}.trade-inputs{grid-template-columns:1fr;gap:10px}.mobile-trading-only .trading-panel{padding:10px}.mobile-trading-only .broker-order-topbar{grid-template-columns:minmax(0,1.2fr) repeat(2,minmax(0,.8fr))}.mobile-trading-only .broker-stepper-grid{grid-template-columns:minmax(0,1.1fr) minmax(0,.9fr);gap:6px;margin-bottom:0}.mobile-market-stack .mobile-book-panel{min-height:280px}.mobile-chart-detail-shell{min-height:320px}.tick-table th{padding:8px 3px;font-size:12px}.tick-table td{padding:7px 3px;font-size:12px}.tick-time{font-size:12px}.trade-type-selector{grid-template-columns:repeat(2,minmax(0,1fr));gap:6px;padding:6px;display:grid}.mobile-trading-only .trade-type-selector{background:0 0;border:none;grid-template-columns:repeat(3,minmax(0,1fr));gap:6px;margin-bottom:8px;padding:0}.trade-buttons{flex-direction:column}.mobile-trading-only .trade-buttons{flex-direction:row;gap:8px}.summary-stats{padding:10px 12px}.table-area{padding:6px 8px}.trading-panel{padding:10px 12px}.trade-inputs{grid-template-columns:1fr;gap:8px;margin-bottom:8px}.trade-mode-chip{padding:7px 8px;font-size:12px}.mobile-trading-only .trade-mode-chip{padding:7px 4px;font-size:11px}.mobile-trading-only .broker-order-topbar{margin-bottom:8px}.mobile-trading-only .trade-mode-hint{margin-bottom:4px;font-size:10px}.mobile-trading-only .broker-stepper-card{gap:2px;min-width:0}.mobile-trading-only .broker-stepper-label{margin-bottom:2px;font-size:10px}.broker-stepper-control{grid-template-columns:32px minmax(0,1fr) 32px}.mobile-trading-only .broker-stepper-control{grid-template-columns:28px minmax(0,1fr) 28px;min-height:34px}.mobile-trading-only .broker-stepper-btn{padding:0;font-size:18px}.broker-stepper-control input{font-size:18px}.mobile-trading-only .broker-stepper-control input{padding:4px 2px;font-size:15px}.mobile-trading-only .broker-order-note{text-align:right;margin-top:2px;margin-bottom:6px;font-size:10px;line-height:1.2}.mobile-trading-only .btn{border-radius:5px;min-height:38px;padding:6px 8px;font-size:13px}.mobile-trading-only .trade-buttons{gap:6px}.mobile-stage .bottom-panel{box-shadow:none;background:0 0;border:none}.mobile-stage-account .bottom-panel{flex:none;width:100%;height:auto;min-height:100%;max-height:none;overflow:visible}.mobile-stage .bottom-panel-body{flex-direction:column;flex:auto;min-height:0;display:flex;overflow:hidden}.mobile-stage .mobile-portfolio-stack{height:100%;min-height:0;overflow:hidden}.mobile-stage .mobile-record-list{flex:auto;min-height:0}.mobile-stage-account .bottom-panel-body,.mobile-stage-account .mobile-portfolio-stack,.mobile-stage-account .mobile-record-list{overflow:visible}.mobile-stage .bottom-tabs{background:0 0;border-bottom:none;gap:8px;padding:0;overflow:visible}.mobile-stage .bottom-tab{text-align:center;border:1px solid var(--border-color);min-width:0;box-shadow:var(--shadow-soft);background:#fff;border-radius:16px;flex:1 1 0;padding:12px 8px;font-size:12px}.mobile-stage .bottom-tab.active{color:var(--color-primary);background:#3b82f617;border-color:#60a5fa8c}.mobile-summary-grid{grid-template-columns:1fr 1fr}.mobile-chart-detail-header{flex-wrap:wrap;align-items:stretch}.mobile-chart-detail-tabs{justify-content:stretch;width:100%}.mobile-chart-detail-tab{flex:1 1 0;min-width:0}.mobile-chart-detail-summary{text-align:right;width:100%;margin-left:0}.mobile-chart-detail-body{min-height:280px;max-height:min(44vh,380px)}.mobile-summary-card .val{font-size:16px}.mobile-record-grid{grid-template-columns:1fr 1fr;gap:8px 10px}.input-group input{padding:7px;font-size:16px}.btn{padding:9px;font-size:15px}.mobile-switch-btn{padding:9px 8px;font-size:12px}.modal-overlay{padding:12px}.modal-content{width:100%;max-height:calc(100vh - 24px);padding:18px;overflow:auto}.modal-content .form-row{flex-direction:column;align-items:stretch;gap:6px}.modal-content .form-row input{text-align:left;width:100%}.modal-content .modal-btns{flex-direction:column}}
