*{box-sizing:border-box}body{color:#17202a;background:#f4f6f8;margin:0;font-family:Inter,ui-sans-serif,system-ui,-apple-system,BlinkMacSystemFont,Segoe UI,sans-serif}button,input,select{font:inherit}button{color:#fff;cursor:pointer;background:#17202a;border:1px solid #17202a;border-radius:8px;justify-content:center;align-items:center;gap:8px;height:38px;padding:0 14px;display:inline-flex}button:disabled{cursor:not-allowed;opacity:.55}input,select{color:#17202a;background:#fff;border:1px solid #cfd6dd;border-radius:8px;min-width:0;height:38px;padding:0 10px}.app{max-width:none;margin:0 auto;padding:6px}.topbar{background:#fff;border:1px solid #dbe1e7;border-radius:8px;justify-content:space-between;align-items:center;gap:16px;padding:16px;display:flex}.brand,.actions,.panelHeader,.formRow{align-items:center;gap:12px;display:flex}.brand h1,.panel h2{margin:0;font-size:18px;line-height:1.2}.brand p,.panel p,.note,.label{color:#66717f;margin:0}.brand p,.panel p,.note{font-size:12px}.actions{flex-wrap:wrap;justify-content:flex-end}.pageTabs{background:#eef3f8;border:1px solid #d7e0ea;border-radius:8px;gap:2px;padding:3px;display:inline-flex}.pageTab{color:#49627b;background:0 0;border:0;border-radius:6px;height:32px;padding:0 10px}.pageTab.active{color:#fff;background:#17202a}.status{border-radius:999px;padding:8px 10px;font-size:12px;font-weight:700}.status.open{color:#0f7b45;background:#d9f8e7}.status.closed{color:#41505f;background:#e8edf2}.alert{color:#9f1d1d;background:#fff0f0;border:1px solid #f2bbbb;border-radius:8px;margin-top:16px;padding:12px}.metrics,.miniGrid{grid-template-columns:repeat(4,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.intradayGrid{grid-template-columns:repeat(3,minmax(0,1fr));gap:12px;margin-top:16px;display:grid}.intradayCard{background:linear-gradient(#fff 0%,#f8fbff 100%);border:1px solid #d7e0ea;border-radius:10px;padding:14px;box-shadow:0 8px 24px #1f314614}.intradayHeader{color:#49627b;justify-content:space-between;align-items:flex-start;display:flex}.intradayHeader h3{color:#17202a;margin:0;font-size:16px}.intradayHeader p,.intradayTime{color:#66717f;margin:4px 0 0;font-size:12px}.chartHint{color:#66717f;font-size:11px}.indicatorLegend{color:#4657c8;align-items:center;gap:6px;min-width:0;max-width:100%;margin-top:6px;font-size:11px;font-weight:800;display:inline-flex}.bbLine{background:linear-gradient(90deg,#5f7df2 0 42%,#d19a2d 42% 58%,#5f7df2 58% 100%);border-radius:999px;width:28px;height:3px;display:inline-block}.bbSignal,.rsiSignal{color:#536170;text-overflow:ellipsis;white-space:nowrap;border-radius:999px;padding:4px 7px;font-size:10px;font-weight:800;line-height:1;overflow:hidden}.bbSignal.breakout{color:#0f7b45;background:#e5f8ee}.bbSignal.breakdown{color:#a83227;background:#ffe9e6}.bbSignal.squeeze{color:#8a5d00;background:#fff4cf}.bbSignal.neutral{color:#536170;background:#eef3f8}.rsiSignal.overbought{color:#a83227;background:#ffe9e6}.rsiSignal.oversold{color:#0f7b45;background:#e5f8ee}.rsiSignal.neutral{color:#536170;background:#eef3f8}.intradayPrice{margin-top:14px;font-size:28px;font-weight:800}.intradayChange{margin-top:3px;font-size:13px;font-weight:700}.intradayChange.down{color:#cc3d31}.intradayChange.up{color:#0f8f53}.intradayMeta{color:#3d4c5b;flex-wrap:wrap;gap:10px;margin-top:12px;font-size:12px;display:flex}.miniCandleChart{background:linear-gradient(#f7fafdeb,#fffffffa);border:1px solid #dce4ec;border-radius:8px;height:260px;margin-top:12px;overflow:hidden;box-shadow:inset 0 1px #ffffffe6}.miniCandleChart svg{width:100%;height:100%;display:block}.miniCandle.up .miniWick{stroke:#1e7a46}.miniCandle.up .miniBody{fill:#2fb76d;stroke:#176c3c;stroke-width:.8px}.miniCandle.down .miniWick{stroke:#b83a2d}.miniCandle.down .miniBody{fill:#e25545;stroke:#a63127;stroke-width:.8px}.miniWick{stroke-linecap:round;stroke-width:1px}.tvGridLine{stroke:#e3e9ef;stroke-width:1px}.tvYAxisText,.tvXAxisText{fill:#6a7480;font-size:11px;font-weight:600}.tvLastPriceLine{stroke:#4aa864;stroke-dasharray:5 6;stroke-width:1.2px}.tvPriceTag{fill:#4aa864;filter:drop-shadow(0 2px 4px #2d523740)}.tvPriceTagText{fill:#fff;font-size:11px;font-weight:700}.bollingerOuter{fill:none;stroke:#5f7df2;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.8px}.bollingerMiddle{fill:none;stroke:#d19a2d;stroke-dasharray:4 4;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.5px}.intradayTime{border-top:1px solid #edf2f6;margin-top:10px;padding-top:8px}.miniEmpty{color:#b7c3d4;justify-content:center;align-items:center;height:100%;font-size:12px;display:flex}.miniDragCapture{cursor:grab;fill:#0000;pointer-events:all}.miniDragCapture:active{cursor:grabbing}.miniHoverLine{stroke:#9da8b8;stroke-dasharray:2 4;stroke-width:1px}.miniHoverDot{fill:#ff8b7f;stroke:#ffd1cc;stroke-width:1.4px}.miniTooltipHtml,.chartTooltipHtml{color:#dbe5f0;background:#14171cf7;border-radius:4px;width:142px;height:42px;padding:8px;font-size:10.5px}.chartTooltipHtml{width:204px}.miniTooltipTop{justify-content:space-between;align-items:center;display:flex}.miniTooltipTop strong{color:#fff;font-size:13px}.miniTooltipTop span{color:#b9c3d0}.miniTooltipRows{grid-template-columns:1fr;gap:6px;padding-top:7px;display:grid}.miniTooltipRows span{white-space:nowrap;justify-content:space-between;align-items:center;gap:6px;min-width:0;display:flex}.miniTooltipRows b{color:#9fc3ff;align-items:center;gap:4px;min-width:52px;font-size:10px;font-weight:700;display:inline-flex}.miniTooltipRows svg{flex:none}.intradayOhlc{border-top:1px solid #edf2f6;grid-template-columns:repeat(4,minmax(0,1fr));gap:6px 10px;margin-top:10px;padding-top:9px;display:grid}.intradayOhlc div{min-width:0}.intradayOhlc span{color:#66717f;text-transform:uppercase;align-items:center;gap:4px;font-size:10px;font-weight:700;display:flex}.intradayOhlc svg{color:#49627b;flex:none}.intradayOhlc strong{color:#17202a;text-overflow:ellipsis;white-space:nowrap;margin-top:2px;font-size:12px;font-weight:800;display:block;overflow:hidden}.miniGrid{grid-template-columns:repeat(2,minmax(0,1fr))}.tile,.panel{background:#fff;border:1px solid #dbe1e7;border-radius:8px}.tile{justify-content:space-between;min-height:104px;padding:16px;display:flex}.tileIcon{color:#49627b;flex:none}.label{text-transform:uppercase;font-size:12px;font-weight:700}.value{margin:8px 0 4px;font-size:24px;font-weight:800}.grid{gap:16px;margin-top:16px;display:grid}.grid.two{grid-template-columns:repeat(2,minmax(0,1fr))}.panel{min-width:0;padding:8px}.panelHeader{justify-content:space-between;margin-bottom:14px}.formRow{margin-bottom:14px}.formRow input{flex:1}.formRow.compact{grid-template-columns:42px auto;justify-content:end;align-items:stretch;display:grid}.iconButton{width:42px;padding:0}.smallButton{height:38px;padding:0 12px}.json{color:#e7edf3;background:#111820;border-radius:8px;max-height:360px;margin:0;padding:14px;font-size:12px;line-height:1.55;overflow:auto}.tableWrap{border:1px solid #dbe1e7;border-radius:8px;max-height:430px;overflow:auto}.modalBackdrop{z-index:20;background:#0a0e14a3;justify-content:center;align-items:center;padding:24px;display:flex;position:fixed;inset:0}.modal{background:#fff;border-radius:8px;width:min(1180px,96vw);max-width:1180px;max-height:88vh;padding:16px;overflow:hidden;box-shadow:0 18px 60px #00000059}.modalHeader{justify-content:space-between;align-items:center;margin-bottom:14px;display:flex}.modalHeader h2{margin:0;font-size:18px}.modalHeader p{color:#66717f;margin:4px 0 0;font-size:12px}.modalTable{max-height:calc(88vh - 92px)}.marketCard{color:#f2f6fb;background:#20242a;border-radius:0;margin:8px 0 14px;padding:12px 18px 14px}.marketHeader{justify-content:space-between;align-items:flex-start;gap:16px;display:flex}.marketHeader h2{color:#f6f3e9;letter-spacing:0;margin:0 0 6px;font-size:28px;font-weight:500}.marketHeader p,.marketTime{color:#d8e8ff;margin:0;font-size:13px}.followButton{color:#07111f;background:#b8d2fb;border-color:#b8d2fb;border-radius:999px;height:32px;margin-top:20px}.marketPriceRow{justify-content:space-between;margin-top:18px;display:flex}.marketPrice{color:#f8f7f5;font-size:36px;font-weight:500;line-height:1.1}.marketChange{margin-top:6px;font-size:15px}.marketChange.down{color:#ff8b7f}.marketChange.up{color:#68d391}.marketTime{color:#aebdd0;margin-top:10px}.rangeTabs{border-bottom:0;grid-template-columns:repeat(9,minmax(0,1fr));align-items:center;gap:0;margin-top:18px;display:grid}.rangeTabs span,.rangeTab{color:#b7c3d4;background:0 0;border:0;border-radius:0;justify-content:flex-start;height:28px;padding:0;font-size:14px;position:relative}.rangeTab{cursor:pointer}.rangeTab.active{color:#93bfff}.rangeTab.active:after{content:"";background:#91baff;border-radius:999px;width:24px;height:4px;position:absolute;bottom:-2px;left:0}.chartFrame{width:100%;height:350px;margin-top:14px;position:relative}.chartFrame svg{width:100%;height:100%;display:block}.gridLine{stroke:#3a3f46;stroke-width:1px}.previousLine{stroke:#a8b1bf;stroke-dasharray:1 8;stroke-linecap:round;stroke-width:1.2px}.flatPreviousLine{stroke:#58d68d;stroke-dasharray:1 3;stroke-linecap:round;stroke-width:1.5px}.axisText,.timeText,.previousLabel,.previousValue{fill:#bdd0e7;font-size:14px}.previousLabel{fill:#b8c5d8;font-size:14px}.previousValue{fill:#cfd9e8;font-size:14px}.areaPath{fill:url(#priceArea)}.linePath{fill:none;stroke:#ff8b7f;stroke-linecap:round;stroke-linejoin:round;stroke-width:2px}.flatLinePath{fill:none;stroke:#58d68d;stroke-dasharray:1 3;stroke-linecap:round;stroke-linejoin:round;stroke-width:1.5px}.lastDot{fill:#ff8b7f;stroke:#20242a;stroke-width:2px}.candle.up .wick{stroke:#58d68d}.candle.up .body{fill:#58d68d}.candle.down .wick{stroke:#ff8b7f}.candle.down .body{fill:#ff8b7f}.wick{stroke-linecap:round;stroke-width:1.2px}.hoverCapture{cursor:grab;fill:#0000;pointer-events:all}.hoverCapture:active{cursor:grabbing}.hoverLine{stroke:#c5cdd8;stroke-dasharray:2 4;stroke-width:1px}.hoverDot{fill:#ff8b7f;stroke:#ffd1cc;stroke-width:1.5px}.tooltipBox{fill:#14171c;opacity:.96}.tooltipPrice{fill:#fff;font-size:13px;font-weight:700}.tooltipTime{fill:#9da8b8;font-size:11px}.chartStats{grid-template-columns:repeat(4,minmax(130px,1fr));gap:10px 48px;max-width:820px;margin-top:8px;display:grid}.chartStats div{justify-content:space-between;align-items:center;display:flex}.chartStats span{color:#e4edf8;align-items:center;gap:6px;font-size:14px;display:inline-flex}.chartStats svg{color:#9fc3ff;flex:none}.chartStats strong{color:#bcd0e8;font-size:14px;font-weight:500}.paperPage{gap:14px;margin-top:16px;display:grid}.paperControlPanel{padding:14px}.paperControls{flex-wrap:wrap;align-items:end;gap:12px;display:flex}.paperControls label{gap:5px;display:grid}.paperControls label span,.strategySetup label span{color:#66717f;text-transform:uppercase;font-size:11px;font-weight:800}.strategySetup{border-top:1px solid #edf2f6;grid-template-columns:repeat(7,minmax(110px,1fr));gap:12px;margin-top:14px;padding-top:14px;display:grid}.strategySetup label{gap:5px;display:grid}.strategySetup input{width:100%}.paperLayout{grid-template-columns:1fr;gap:14px;display:grid}.paperSidePanel{min-width:0;padding:14px}.paperReplayHeader{justify-content:space-between;align-items:flex-start;gap:12px;margin-bottom:10px;display:flex}.paperReplayHeader h2,.paperSidePanel h2{margin:0;font-size:18px}.paperCandleReadout{color:#66717f;justify-items:end;gap:3px;display:grid}.paperCandleReadout strong{color:#17202a;font-size:20px}.replayControls,.paperTradeButtons{flex-wrap:wrap;align-items:center;gap:8px;margin-top:12px;display:flex}.inlineReplayControls{margin-top:0}.strategyToggle{color:#17202a;background:#eef3f8;border-color:#cfd9e3}.strategyToggle.active{color:#fff;background:#0f7b45;border-color:#0f7b45}.replayProgress{color:#66717f;margin-left:auto;font-size:12px;font-weight:700}.paperTradeButtons{grid-template-columns:repeat(3,minmax(0,1fr));align-items:stretch;display:grid}.paperTradeButtons button{padding:0 10px}.paperStats{gap:10px;margin-top:14px;display:grid}.paperStats div{border-bottom:1px solid #edf2f6;justify-content:space-between;align-items:center;padding-bottom:8px;display:flex}.paperStats span{color:#66717f;font-size:12px}.paperStats strong{font-size:14px}.profitText{color:#0f7b45;font-weight:800}.lossText{color:#a83227;font-weight:800}.strategyText{text-align:right}.strategyText.buy{color:#0f7b45}.strategyText.sell{color:#a83227}.strategyText.hold{color:#536170}.emptyChart{color:#b7c3d4;justify-content:center;align-items:center;height:100%;display:flex}table{border-collapse:collapse;width:100%;font-size:12px}th,td{text-align:right;white-space:nowrap;border-bottom:1px solid #edf1f5;padding:9px 10px}th:first-child,td:first-child{text-align:left}th{color:#4b5c6d;background:#f8fafc;font-weight:800;position:sticky;top:0}.spin{animation:.9s linear infinite spin}@keyframes spin{to{transform:rotate(360deg)}}@media (width<=980px){.topbar,.grid.two{grid-template-columns:1fr}.topbar{align-items:stretch;display:grid}.metrics{grid-template-columns:repeat(2,minmax(0,1fr))}.intradayGrid,.paperLayout{grid-template-columns:1fr}.strategySetup{grid-template-columns:repeat(2,minmax(0,1fr))}}@media (width<=680px){.app{padding:12px}.metrics,.miniGrid,.formRow.compact{grid-template-columns:1fr}.formRow{flex-direction:column;align-items:stretch}.actions{justify-content:flex-start}.paperReplayHeader,.paperControls{flex-direction:column;align-items:stretch}.paperTradeButtons,.strategySetup{grid-template-columns:1fr}}
