.navbar{background:#1e293b;border-bottom:1px solid #334155;padding:0;box-shadow:0 2px 4px #0000001a}.navbar-container{max-width:1400px;margin:0 auto;display:flex;gap:.5rem;padding:.75rem 2rem}.nav-link{color:#cbd5e1;text-decoration:none;padding:.5rem 1.5rem;border-radius:6px;font-weight:500;font-size:.9375rem;transition:all .2s;border:1px solid transparent}.nav-link:hover{background:#334155;color:#fff}.nav-link.active{background:#2563eb;color:#fff;border-color:#3b82f6}.strategy-selector{min-width:200px;display:flex;flex-direction:column;gap:.75rem}.select-input{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;background-color:#fff;cursor:pointer;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23334155' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px}.stock-selector{min-width:150px;display:flex;flex-direction:column;gap:.75rem}.select-input{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;background-color:#fff;cursor:pointer;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23334155' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px}.time-period-selector{min-width:180px;display:flex;flex-direction:column;gap:.75rem}.select-input{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;background-color:#fff;cursor:pointer;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23334155' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px}.shares-selector{min-width:200px;display:flex;flex-direction:column;gap:.75rem}.select-input{width:100%;padding:.75rem 2.5rem .75rem .75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;background-color:#fff;cursor:pointer;transition:border-color .2s;-webkit-appearance:none;-moz-appearance:none;appearance:none;background-image:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' width='12' height='12' viewBox='0 0 12 12'%3E%3Cpath fill='%23334155' d='M6 9L1 4h10z'/%3E%3C/svg%3E");background-repeat:no-repeat;background-position:right .75rem center;background-size:12px}.select-input:hover{border-color:#94a3b8}.select-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.fixed-shares-input{margin-top:.5rem;display:flex;flex-direction:column;gap:.25rem}.number-input{width:100%;padding:.75rem;border:2px solid #e0e0e0;border-radius:6px;font-size:1rem;transition:border-color .2s}.number-input:hover{border-color:#94a3b8}.number-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.chart-display{width:100%;display:flex;flex-direction:column}.transaction-details-banner{background:#f8f9fa;border:1px solid #e2e8f0;border-radius:6px;padding:1rem;margin-bottom:1rem;display:flex;justify-content:space-between;align-items:center;box-shadow:0 1px 3px #00000014;gap:1rem}.transaction-details-content{flex:1;display:flex;flex-direction:column;gap:.5rem}.transaction-details-row{display:flex;align-items:center;gap:1rem;flex-wrap:wrap}.transaction-label{font-weight:600;color:#475569;font-size:.875rem}.transaction-value{color:#1e293b;font-size:.875rem;font-weight:500}.transaction-value.profit{color:#059669;font-weight:600}.transaction-value.loss{color:#dc2626;font-weight:600}.transaction-details-actions{display:flex;align-items:center;gap:.5rem;flex-shrink:0}.transaction-nav-btn{background:#334155;border:1px solid #475569;color:#e2e8f0;font-size:1.25rem;line-height:1;cursor:pointer;padding:.5rem .75rem;border-radius:4px;transition:all .2s;width:36px;height:36px;display:flex;align-items:center;justify-content:center;font-weight:600}.transaction-nav-btn:hover:not(:disabled){background:#475569;border-color:#64748b;color:#fff}.transaction-nav-btn:disabled{opacity:.4;cursor:not-allowed}.transaction-details-close{background:transparent;border:none;color:#64748b;font-size:1.5rem;line-height:1;cursor:pointer;padding:.25rem .5rem;border-radius:4px;transition:all .2s;width:28px;height:28px;display:flex;align-items:center;justify-content:center}.transaction-details-close:hover{background:#e2e8f0;color:#1e293b}.position-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.position-badge.long{background:#d1fae5;color:#065f46}.position-badge.short{background:#fee2e2;color:#991b1b}.chart-container{flex:1;position:relative}.chart-display p{text-align:center;padding:2rem;color:#666}.chart-controls-bar{display:flex;align-items:center;background:#1e293b;border-top:1px solid #334155;padding:.5rem 1rem;min-height:40px;gap:.5rem}.mouse-mode-controls{display:flex;gap:.25rem;border-right:1px solid #334155;padding-right:.5rem;margin-right:.5rem}.chart-control-btn{display:flex;align-items:center;gap:.5rem;background:#334155;color:#e2e8f0;border:1px solid #475569;border-radius:4px;padding:.5rem 1rem;font-size:.875rem;cursor:pointer;transition:all .2s;font-weight:500}.chart-control-btn:hover{background:#475569;border-color:#64748b;color:#fff}.chart-control-btn:active{background:#1e293b;transform:scale(.98)}.zoom-in-btn{background:#2563eb;border-color:#3b82f6;color:#fff}.zoom-in-btn:hover{background:#1d4ed8;border-color:#2563eb}.zoom-out-btn{background:#2563eb;border-color:#3b82f6;color:#fff}.zoom-out-btn:hover{background:#1d4ed8;border-color:#2563eb}.reset-zoom-btn{background:#64748b;border-color:#94a3b8;color:#fff}.reset-zoom-btn:hover{background:#475569;border-color:#64748b}.chart-control-btn.active{background:#2563eb;border-color:#3b82f6;color:#fff}.chart-control-btn.active:hover{background:#1d4ed8;border-color:#2563eb}.control-icon{font-size:1rem;line-height:1}.control-label{font-size:.875rem}.chart-controls-spacer{flex:0 0 auto}.chart-info{display:flex;align-items:center;color:#cbd5e1;font-size:.875rem;font-weight:500}.chart-strategy-name{color:#e2e8f0;font-weight:600}.zoom-slider-container{display:flex;align-items:center;gap:.75rem;padding:0 .5rem;border-right:1px solid #334155;margin-right:.5rem;flex:1 1 auto;min-width:0;max-width:none}.zoom-label{color:#cbd5e1;font-size:.875rem;font-weight:500;white-space:nowrap;flex-shrink:0}.zoom-slider{flex:1 1 auto;width:100%;min-width:500px;height:4px;background:#475569;border-radius:2px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:14px;height:14px;background:#2563eb;border-radius:50%;cursor:pointer;transition:background .2s}.zoom-slider::-webkit-slider-thumb:hover{background:#1d4ed8}.zoom-slider::-moz-range-thumb{width:14px;height:14px;background:#2563eb;border-radius:50%;cursor:pointer;border:none;transition:background .2s}.zoom-slider::-moz-range-thumb:hover{background:#1d4ed8}.zoom-value{color:#e2e8f0;font-size:.875rem;font-weight:600;min-width:40px;text-align:right;flex-shrink:0}.transaction-list{width:100%}.transaction-list h2{margin-bottom:1rem;color:#333;font-size:1.5rem}.no-trades{text-align:center;padding:2rem;color:#666;font-style:italic}.table-container{overflow-x:auto}.transactions-table{width:100%;border-collapse:collapse;font-size:.9rem;table-layout:fixed}.transactions-table thead{background-color:#f8f9fa;border-bottom:2px solid #dee2e6}.transactions-table th{padding:.75rem;text-align:left;font-weight:600;color:#495057;text-transform:uppercase;font-size:.85rem;letter-spacing:.5px;white-space:nowrap;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.transactions-table td{padding:.75rem;border-bottom:1px solid #dee2e6;text-align:left;vertical-align:middle;overflow:hidden;text-overflow:ellipsis}.transactions-table th:nth-child(1),.transactions-table td:nth-child(1){width:12%}.transactions-table th:nth-child(2),.transactions-table td:nth-child(2){width:12%}.transactions-table th:nth-child(3),.transactions-table td:nth-child(3){width:12%}.transactions-table th:nth-child(4),.transactions-table td:nth-child(4){width:8%}.transactions-table th:nth-child(5),.transactions-table td:nth-child(5){width:10%;text-align:right}.transactions-table th:nth-child(6),.transactions-table td:nth-child(6){width:10%;text-align:right}.transactions-table th:nth-child(7),.transactions-table td:nth-child(7){width:10%;text-align:right}.transactions-table th:nth-child(8),.transactions-table td:nth-child(8){width:8%;text-align:right}.transactions-table th:nth-child(9),.transactions-table td:nth-child(9){width:8%;text-align:right}.transactions-table th:nth-child(10),.transactions-table td:nth-child(10){width:8%;text-align:right}.transactions-table tbody tr:hover{background-color:#f8f9fa}.transactions-table tbody tr[style*="cursor: pointer"]:hover{background-color:#f1f5f9;transform:scale(1.01);transition:all .2s ease}.transactions-table tbody tr:last-child td{border-bottom:none}.profit{color:#28a745;font-weight:600}.loss{color:#dc3545;font-weight:600}.position-badge{display:inline-block;padding:.25rem .5rem;border-radius:4px;font-size:.8rem;font-weight:600;text-transform:uppercase}.position-badge.long{background-color:#d4edda;color:#155724}.position-badge.short{background-color:#f8d7da;color:#721c24}.position-badge.missed{opacity:.6;position:relative}.position-badge.missed:after{content:"";position:absolute;left:0;right:0;top:50%;height:2px;background-color:currentColor}.missed-trade{background-color:#f8f9fa;opacity:.7}.missed-trade:hover{background-color:#e9ecef!important;opacity:.85}.strikethrough{text-decoration:line-through;color:#6c757d}.missed-label{color:#dc3545!important;font-weight:600;text-decoration:none!important}.missed-count{font-size:.85rem;font-weight:400;color:#dc3545;margin-left:.5rem}.limit-label{font-size:.7rem;color:#6c757d;margin-left:.25rem;display:inline-block}.limit-filled{font-size:.75rem;margin-left:.25rem;font-weight:600;display:inline-block}.limit-filled.better{color:#28a745}.limit-filled.worse{color:#dc3545}@media (max-width: 768px){.transactions-table{font-size:.8rem}.transactions-table th,.transactions-table td{padding:.5rem}}.statistics-panel{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0;margin-bottom:2rem}.statistics-panel h2{margin-bottom:1.5rem;color:#333;font-size:1.5rem}.stats-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem}.stat-card{background:#f8f9fa;padding:1rem;border-radius:6px;border-left:4px solid #2563eb;transition:transform .2s,box-shadow .2s}.stat-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #0000001a}.stat-card.highlight{background:linear-gradient(135deg,#2563eb 0%,#1d4ed8 100%);color:#fff;border-left:none}.stat-card.highlight .stat-label{color:#fffffff2}.stat-label{font-size:.85rem;color:#1e293b!important;margin-bottom:.5rem;font-weight:600;text-transform:uppercase;letter-spacing:.5px}.stat-value{font-size:1.5rem;font-weight:700;color:#1e293b!important}.stat-card.highlight .stat-value{color:#fff!important;font-size:1.75rem}.stat-value.positive{color:#28a745!important}.stat-value.negative{color:#dc3545!important}.stat-card.highlight .stat-value.positive{color:#4ade80}.stat-card.highlight .stat-value.negative{color:#f87171}@media (max-width: 768px){.stats-grid{grid-template-columns:repeat(auto-fit,minmax(150px,1fr))}.stat-value{font-size:1.2rem}}.app{min-height:100vh;background-color:#f5f5f5}.app-header{background:linear-gradient(135deg,#1e293b 0%,#334155 100%);color:#fff;padding:2rem;text-align:center;box-shadow:0 2px 8px #0000001a}.app-header h1{font-size:2.5rem;margin-bottom:.5rem}.app-header p{font-size:1.1rem;opacity:.9}.app-container{max-width:1400px;margin:0 auto;padding:2rem}.controls-panel{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0;margin-bottom:2rem}.controls-panel-title{font-size:1.25rem;font-weight:600;color:#1e293b;margin-bottom:1.5rem;padding-bottom:.75rem;border-bottom:2px solid #e2e8f0}.controls-grid{display:flex;gap:1rem;flex-wrap:wrap;align-items:flex-end}.control-group{display:flex;flex-direction:column;gap:.75rem}.control-group label{font-weight:600;color:#333;font-size:.9rem}.run-button{background:#2563eb;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-size:1rem;font-weight:600;cursor:pointer;transition:background-color .2s,transform .2s,box-shadow .2s}.run-button:hover:not(:disabled){background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 12px #2563eb4d}.run-button:disabled{opacity:.6;cursor:not-allowed}.error-message{background-color:#fee;color:#c33;padding:.75rem 1rem;border-radius:6px;border:1px solid #fcc;margin-top:1rem}.loading-message{background:white;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0;text-align:center;margin:2rem 0}.loading-message p{font-size:1.1rem;color:#2563eb;font-weight:500;margin-bottom:1.5rem}.strategy-description-preview{margin-top:1.5rem;padding:1rem;background:#f8f9fa;border-radius:6px;text-align:left;border-left:4px solid #2563eb}.strategy-description-preview h3{font-size:1rem;color:#1e293b;margin-bottom:.5rem}.strategy-description-preview p{font-size:.9rem;color:#475569;line-height:1.6;margin:0}.strategy-description-banner{background:#f1f5f9;border-left:4px solid #2563eb;padding:1rem 1.5rem;border-radius:6px;margin-bottom:1.5rem;font-size:.9rem;color:#334155;line-height:1.6}.results-section{margin-bottom:2rem}.chart-section{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0;margin-bottom:2rem}.transactions-section{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #00000014;border:1px solid #e2e8f0}@media (max-width: 768px){.controls-grid{flex-direction:column}.control-group{width:100%}}.ma-predictor-new{height:calc(100vh - 60px);display:flex;flex-direction:column;background:#f8fafc;overflow:hidden}.ma-header{display:flex;align-items:center;justify-content:space-between;padding:.75rem 1.5rem;background:white;border-bottom:1px solid #e5e7eb;flex-shrink:0}.ticker-selector{display:flex;align-items:center;gap:1rem}.pinned-tickers{display:flex;gap:.5rem}.ticker-btn{padding:.5rem 1rem;border:1px solid #d1d5db;border-radius:6px;background:white;font-weight:600;font-size:.875rem;color:#374151;cursor:pointer;transition:all .2s}.ticker-btn:hover{background:#f3f4f6;border-color:#9ca3af}.ticker-btn.active{background:#1e293b;border-color:#1e293b;color:#fff}.ticker-search{display:flex;gap:.5rem}.ticker-input{padding:.5rem .75rem;border:1px solid #d1d5db;border-radius:6px;font-size:.875rem;width:120px}.ticker-input:focus{outline:none;border-color:#3b82f6}.ticker-go-btn{padding:.5rem 1rem;background:#3b82f6;color:#fff;border:none;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.ticker-go-btn:hover{background:#2563eb}.market-status-container{display:flex;align-items:center;gap:.75rem}.market-status{font-size:.875rem;font-weight:500}.status-open{color:#059669}.status-pre{color:#d97706}.status-post{color:#7c3aed}.status-closed{color:#6b7280}.refresh-btn{padding:.375rem .75rem;font-size:.75rem;font-weight:500;color:#3b82f6;background:#eff6ff;border:1px solid #bfdbfe;cursor:pointer;transition:all .15s}.refresh-btn:hover{background:#dbeafe;color:#2563eb}.refresh-btn:disabled{cursor:not-allowed;opacity:.7}.refresh-btn.refreshing{color:#6b7280;background:#f3f4f6;border-color:#d1d5db}.refresh-btn.refreshing:first-letter{display:inline-block;animation:spin 1s linear infinite}.ma-content{flex:1;display:flex;gap:0;overflow:hidden}.ma-chart-container{flex:1;display:flex;flex-direction:column;background:white;border-right:1px solid #e5e7eb;overflow:hidden;min-width:0}.ma-chart-container .js-plotly-plot,.ma-chart-container .plotly{flex:1;min-height:0;width:100%!important}.candle-stats-bar{display:flex;align-items:center;gap:.5rem;padding:.5rem 1rem;background:white;border-bottom:1px solid #e5e7eb;flex-wrap:nowrap;flex-shrink:0;overflow-x:auto;min-height:44px}.candle-stats-bar.is-edited{background:#1e293b;border-bottom:2px solid #f59e0b}.candle-stats-bar.is-edited .ticker-label{color:#f59e0b;background:rgba(245,158,11,.15)}.candle-stats-bar.is-edited .current-price{color:#34d399}.candle-stats-bar.is-edited .stat-divider{background:#475569}.candle-stats-bar.is-edited .stat-label{color:#94a3b8}.candle-stats-bar.is-edited .stat-value{color:#e2e8f0}.candle-stats-bar.is-edited .hint-text{color:#94a3b8}.ticker-label{font-size:1rem;font-weight:700;color:#6366f1;background:rgba(99,102,241,.1);padding:.2rem .5rem;white-space:nowrap}.current-price{font-size:.9375rem;font-weight:600;color:#059669;white-space:nowrap}.stat-divider{width:1px;height:20px;background:#e5e7eb;margin:0 .25rem}.stat-label{font-size:.8125rem;font-weight:500;color:#6b7280;white-space:nowrap}.stat-value{font-size:.875rem;font-weight:600;color:#1e293b;margin-right:.25rem;white-space:nowrap}.stat-input{width:80px;padding:.25rem .375rem;font-size:.875rem;font-weight:600;color:#1e293b;border:1px solid #d1d5db;background:white}.stat-input:focus{outline:none;border-color:#3b82f6}.candle-stats-bar.is-edited .stat-input{border-color:#f59e0b;background:#0f172a;color:#f8fafc}.restore-btn{margin-left:auto;padding:.25rem .5rem;font-size:.75rem;font-weight:600;color:#fff;background:#f59e0b;border:none;cursor:pointer;transition:background .2s;white-space:nowrap}.restore-btn:hover{background:#d97706}.hint-text{font-size:.875rem;color:#9ca3af;font-style:italic;margin-left:auto}.chart-header{display:flex;align-items:center;gap:1rem;padding:.75rem 1.5rem;border-bottom:1px solid #f0f0f0}.chart-controls-bar{display:flex;align-items:center;gap:.5rem;padding:.25rem .5rem;flex-shrink:0}.control-btn{display:flex;align-items:center;gap:.25rem;padding:.375rem .625rem;background:#f1f5f9;border:1px solid #e2e8f0;border-radius:4px;color:#64748b;font-size:.75rem;font-weight:500;cursor:pointer;transition:all .15s}.control-btn:hover{background:#e2e8f0;color:#334155}.control-btn.active{background:#3b82f6;border-color:#3b82f6;color:#fff}.control-btn .control-icon{font-size:.875rem}.chart-ticker{font-size:1.5rem;font-weight:700;color:#1e293b}.chart-price{font-size:1.25rem;font-weight:600;color:#059669}.loading-state,.error-state{flex:1;display:flex;align-items:center;justify-content:center;font-size:1rem;color:#6b7280}.error-state{color:#dc2626}.ma-chart-container .js-plotly-plot{flex:1}.ma-predictor-tool{width:340px;flex-shrink:0;background:white;padding:1.5rem;display:flex;flex-direction:column;gap:1.25rem;overflow-y:auto}.ma-predictor-tool h3{margin:0;font-size:1.125rem;font-weight:700;color:#1e293b}.tool-description{margin:0;font-size:.875rem;color:#6b7280}.predict-tomorrow-toggle{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#374151;cursor:pointer;padding:.5rem .75rem;background:#f0fdf4;border:1px solid #bbf7d0;border-radius:6px}.predict-tomorrow-toggle input[type=checkbox]{width:16px;height:16px;cursor:pointer;accent-color:#059669}.predict-tomorrow-toggle span{-webkit-user-select:none;user-select:none}.price-slider-container{display:flex;flex-direction:column;align-items:center;padding:1.5rem .5rem;background:#f8fafc;border-radius:12px}.slider-labels{display:flex;justify-content:space-between;width:100%;font-size:.8125rem;font-weight:600;color:#64748b;margin-bottom:1rem}.slider-range-inputs{display:flex;justify-content:space-between;width:100%;gap:1rem;margin-bottom:1rem}.range-input-group{display:flex;align-items:center;gap:.375rem}.range-input-group label{font-size:.75rem;font-weight:600;color:#64748b}.range-input{width:80px;padding:.375rem .5rem;border:1px solid #cbd5e1;border-radius:4px;font-size:.8125rem;text-align:right;background:white}.range-input:focus{outline:none;border-color:#9c27b0;box-shadow:0 0 0 2px #9c27b01a}.price-slider-vertical{width:100%;height:8px;cursor:pointer;accent-color:#9c27b0}.prediction-display{background:#f8fafc;border-radius:8px;padding:1rem;display:flex;flex-direction:column;gap:.75rem}.prediction-row{display:flex;justify-content:space-between;align-items:center}.prediction-row.main{padding-bottom:.75rem;border-bottom:1px solid #e5e7eb;margin-bottom:.25rem}.prediction-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#6b7280}.prediction-value{font-size:.9375rem;font-weight:600;color:#1e293b}.prediction-value.price{font-size:1.25rem;color:#9c27b0}.ma-dot{width:10px;height:10px;border-radius:50%}.ma-dot.ma5{background:#f59e0b}.ma-dot.ma15{background:#333333}.overlay-info{font-size:.8125rem;color:#6b7280;text-align:center;padding:.75rem;background:#f0f9ff;border-radius:6px;border:1px solid #bae6fd}.overlay-info strong{color:#0369a1}.zoom-slider-bar{display:flex;align-items:center;gap:.75rem;padding:.75rem 1rem;background:#1e293b;border-top:1px solid #334155;flex-shrink:0}.zoom-label{font-size:.8125rem;font-weight:500;color:#94a3b8;white-space:nowrap}.zoom-slider{flex:1;height:6px;background:#475569;border-radius:3px;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none;cursor:pointer}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:16px;height:16px;background:#3b82f6;border-radius:50%;cursor:pointer;transition:background .2s}.zoom-slider::-webkit-slider-thumb:hover{background:#2563eb}.zoom-slider::-moz-range-thumb{width:16px;height:16px;background:#3b82f6;border-radius:50%;cursor:pointer;border:none}.zoom-value{font-size:.8125rem;font-weight:600;color:#e2e8f0;min-width:40px;text-align:right}.ma-chart-container .modebar,.ma-chart-container .modebar-container,.ma-chart-container .rangeslider-container,.ma-chart-container .rangeselector-container,.ma-chart-container .xaxislayer-above .rangeslider{display:none!important}.js-plotly-plot .hoverlayer{pointer-events:auto!important}.js-plotly-plot .hovertext{display:none!important}.js-plotly-plot .scatterlayer text{display:block!important;opacity:1!important;pointer-events:none!important}.js-plotly-plot .hoverlayer>g{opacity:0!important}.js-plotly-plot .spikeline{opacity:1!important;display:block!important;pointer-events:none!important}.js-plotly-plot path[stroke-dasharray]{opacity:1!important;display:block!important}.js-plotly-plot .candlesticklayer path{cursor:pointer!important}.trading-game{max-width:100%;margin:0 auto;padding:.5rem}.game-header{background:white;padding:1.5rem;border-radius:8px;box-shadow:0 1px 3px #00000014;margin-bottom:1rem}.game-header h1{margin:0 0 1rem;font-size:1.5rem;color:#1e293b}.game-setup{display:flex;align-items:center;gap:1rem}.setup-field{display:flex;align-items:center;gap:.5rem}.setup-field label{font-weight:600;color:#475569}.date-input,.stock-select{padding:.5rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.875rem;background:white;cursor:pointer}.date-picker{display:flex;gap:.5rem;align-items:center}.date-select{padding:.5rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.875rem;background:white;cursor:pointer}.date-select.year-select{min-width:80px}.date-select.month-select{min-width:120px}.date-select.day-select{min-width:70px}.date-select:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.stock-select{min-width:100px}.stock-select:focus,.date-input:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.start-btn{background:#2563eb;color:#fff;border:none;padding:.5rem 1.5rem;border-radius:6px;font-weight:600;cursor:pointer;transition:background .2s}.start-btn:hover{background:#1d4ed8}.game-layout{display:grid;grid-template-columns:1fr 280px;gap:.75rem}.game-left-column{display:flex;flex-direction:column;gap:.75rem;min-width:0}.game-right-column{display:flex;flex-direction:column;gap:.5rem;min-width:0}.completed-trades-full-width{margin-top:.75rem;width:100%}.completed-trades-full-width .completed-trades-panel{max-height:none}.completed-trades-full-width .transactions-list{max-height:300px;overflow-y:auto}.game-stats-bar{display:flex;flex-wrap:nowrap;gap:1.5rem;background:#1e293b;color:#fff;padding:1rem 1.5rem;border-radius:8px;overflow-x:auto}.stat-item{display:flex;align-items:center;gap:.5rem;white-space:nowrap;flex-shrink:0}.stat-label{font-weight:600;color:#cbd5e1;font-size:1rem}.stat-value{font-weight:500;color:#fff;font-size:1.125rem}.stat-value.profit{color:#10b981}.stat-value.loss{color:#ef4444}.chart-container{background:white;padding:1rem;border-radius:8px;box-shadow:0 1px 3px #00000014;position:relative;overflow:visible}.hover-price-label{position:absolute;pointer-events:none;z-index:10000}.price-ruler-label{position:absolute;left:10px;top:50%;transform:translateY(-50%);pointer-events:none;z-index:1000;background-color:#fffffff2;border:2px solid #2563eb;border-radius:4px;padding:4px 8px;font-size:14px;font-weight:700;color:#2563eb;font-family:Arial,sans-serif;box-shadow:0 2px 4px #0000001a}.candle-stats-bar{display:flex;align-items:center;gap:1.5rem;background:#1e293b;color:#fff;padding:.75rem 1rem;border-radius:6px;margin-bottom:1rem;flex-wrap:wrap}.candle-stats-bar-top{display:flex;align-items:center;gap:1.5rem;color:#1f2937;padding:1rem 0;border-bottom:1px solid #e5e7eb;margin-bottom:.75rem;flex-wrap:nowrap}.candle-stats-bar-top .candle-stat-label{color:#6b7280;font-weight:500;font-size:1rem}.candle-stats-bar-top .candle-stat-value{color:#1f2937;font-weight:600;font-size:1.125rem}.candle-stats-bar-top .close-stats-btn{background:#ef4444;color:#fff;border:none;width:20px;height:20px;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s;padding:0;margin-left:auto}.ticker-symbol-inline{font-size:1.25rem;font-weight:700;color:#1e293b;letter-spacing:.02em;padding-right:.75rem}.refresh-today-btn{display:flex;align-items:center;gap:.375rem;padding:.375rem .75rem;border:1px solid #d1d5db;border-radius:6px;background:linear-gradient(135deg,#f8fafc 0%,#f1f5f9 100%);color:#475569;font-size:.8125rem;font-weight:500;cursor:pointer;transition:all .2s ease;margin-right:1rem;white-space:nowrap}.refresh-today-btn .refresh-icon{font-size:1rem;line-height:1;transition:transform .3s ease}.refresh-today-btn .refresh-text{font-size:.8125rem}.refresh-today-btn:hover:not(:disabled){background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%);border-color:#93c5fd;color:#1d4ed8}.refresh-today-btn:hover:not(:disabled) .refresh-icon{transform:rotate(45deg)}.refresh-today-btn:disabled{cursor:not-allowed}.refresh-today-btn.refreshing{background:linear-gradient(135deg,#eff6ff 0%,#dbeafe 100%);border-color:#3b82f6;color:#1d4ed8}.refresh-today-btn.refreshing .refresh-icon{animation:spin .8s linear infinite}.refresh-today-btn.refreshing .refresh-text{color:#3b82f6}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.candle-stats-bar-top.ticker-only{background:#f8fafc;border:1px solid #e5e7eb;border-radius:8px;padding:.75rem 1rem;margin-bottom:.5rem}.click-hint{font-size:.875rem;color:#9ca3af;font-style:italic}.candle-stats-bar-top.editable{position:relative;background:rgba(59,130,246,.05);border:1px solid rgba(59,130,246,.2);border-radius:8px;padding:.75rem 1rem;margin-bottom:.5rem}.candle-stats-bar-top.is-edited{background:rgba(245,158,11,.08);border-color:#f59e0b66}.candle-stat-item.editable-field{display:flex;align-items:center;gap:.25rem}.candle-stat-input{width:80px;padding:.375rem .5rem;font-size:1rem;font-weight:600;color:#1f2937;border:1px solid #d1d5db;border-radius:4px;background:white;transition:border-color .2s,box-shadow .2s}.candle-stat-input:focus{outline:none;border-color:#3b82f6;box-shadow:0 0 0 3px #3b82f626}.candle-stats-bar-top.is-edited .candle-stat-input{border-color:#f59e0b;background:rgba(245,158,11,.05)}.restore-original-btn{display:flex;align-items:center;gap:.5rem;margin-left:auto;padding:.5rem 1rem;font-size:.875rem;font-weight:600;color:#fff;background:#f59e0b;border:none;border-radius:6px;cursor:pointer;transition:all .2s ease;white-space:nowrap}.restore-original-btn .restore-icon{font-size:1.125rem;line-height:1;transition:transform .3s ease}.restore-original-btn:hover:not(:disabled){background:#d97706}.restore-original-btn:hover:not(:disabled) .restore-icon{transform:rotate(-180deg)}.restore-original-btn:disabled{cursor:not-allowed;opacity:.8}.restore-original-btn.refreshing{background:#3b82f6}.restore-original-btn.refreshing .restore-icon{animation:spin .8s linear infinite}.candle-stats-bar-right{background:white;border:1px solid #e5e7eb;border-radius:4px;padding:.5rem;margin-top:.5rem;box-shadow:0 1px 2px #0000000d}.candle-stats-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.375rem;padding-bottom:.25rem;border-bottom:1px solid #e5e7eb}.candle-stats-header h4{margin:0;font-size:.75rem;font-weight:600;color:#1f2937}.candle-stats-bar-right .candle-stat-item{display:flex;justify-content:space-between;align-items:center;padding:.125rem 0;gap:.375rem}.candle-stats-bar-right .candle-stat-label{font-weight:500;color:#6b7280;font-size:.6875rem}.candle-stats-bar-right .candle-stat-value{font-weight:600;color:#1f2937;font-size:.6875rem}.candle-stats-bar-right .close-stats-btn{background:#ef4444;color:#fff;border:none;width:20px;height:20px;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s;padding:0}.candle-stat-item{display:flex;align-items:center;gap:.5rem}.candle-stat-label{font-weight:600;color:#cbd5e1;font-size:.875rem}.candle-stat-value{font-weight:500;color:#fff;font-size:.875rem}.close-stats-btn{background:#ef4444;color:#fff;border:none;width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s;margin-left:auto}.close-stats-btn:hover{background:#dc2626}.chart-controls-bar{display:flex;align-items:center;gap:1rem;margin-bottom:1rem;padding:.5rem;background:#f8f9fa;border-radius:6px;flex-wrap:wrap}.chart-mode-buttons{display:flex;gap:.5rem;align-items:center}.chart-mode-btn{padding:.5rem 1rem;border:1px solid #cbd5e1;background:white;border-radius:6px;font-weight:600;font-size:.875rem;cursor:pointer;transition:all .2s;color:#475569}.chart-mode-btn:hover{background:#f1f5f9;border-color:#2563eb}.chart-mode-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.chart-mode-btn.reset-btn{background:#64748b;color:#fff;border-color:#64748b}.chart-mode-btn.reset-btn:hover{background:#475569;border-color:#475569}.zoom-slider-container{display:flex;align-items:center;gap:.75rem;flex:1}.zoom-label{font-weight:600;font-size:.875rem;color:#475569;min-width:50px}.zoom-slider{flex:1;height:6px;border-radius:3px;background:#e2e8f0;outline:none;-webkit-appearance:none;-moz-appearance:none;appearance:none}.zoom-slider::-webkit-slider-thumb{-webkit-appearance:none;-moz-appearance:none;appearance:none;width:18px;height:18px;border-radius:50%;background:#2563eb;cursor:pointer}.zoom-slider::-moz-range-thumb{width:18px;height:18px;border-radius:50%;background:#2563eb;cursor:pointer;border:none}.zoom-value{font-weight:600;font-size:.875rem;color:#475569;min-width:45px;text-align:right}.chart-top-buttons{display:flex;justify-content:flex-end;align-items:center;margin-bottom:.75rem;padding:.5rem 0;gap:.75rem}.game-action-buttons{display:flex;flex-direction:row;gap:.375rem;margin-bottom:.5rem}.time-controls{display:flex;flex-direction:row;gap:.5rem;margin-top:.5rem;padding-top:.5rem;border-top:1px solid #e2e8f0;align-items:center}.time-btn{padding:.375rem .75rem;border:1px solid #cbd5e1;background:white;border-radius:4px;cursor:pointer;font-size:.75rem;transition:all .2s}.time-btn:hover:not(:disabled){background:#f8f9fa;border-color:#2563eb}.time-btn:disabled{opacity:.5;cursor:not-allowed}.time-indicator{flex:1;text-align:center;font-weight:600;color:#475569}.action-btn{padding:.375rem 1rem;border:none;border-radius:4px;font-weight:600;font-size:.8125rem;cursor:pointer;transition:all .2s}.action-btn:disabled{opacity:.5;cursor:not-allowed;background:#94a3b8!important}.next-day-btn{background:#10b981;color:#fff}.next-day-btn:hover{background:#059669}.end-game-btn{background:#ef4444;color:#fff}.end-game-btn:hover{background:#dc2626}.restart-btn{background:#2563eb;color:#fff;padding:.75rem 2rem;border:none;border-radius:8px;font-weight:600;font-size:1rem;cursor:pointer;transition:all .2s;margin-top:2rem;width:100%;max-width:300px}.restart-btn:hover{background:#1d4ed8;transform:translateY(-1px);box-shadow:0 4px 6px #0000001a}.tools-panel{background:white;padding:.5rem .625rem;border-radius:6px;box-shadow:0 1px 2px #0000000d;margin-bottom:0}.tools-panel h3{font-size:.8125rem;font-weight:600;margin:0 0 .375rem;color:#1f2937}.tools-checkboxes{display:flex;flex-direction:column;gap:.25rem}.tool-checkbox{display:flex;align-items:center;gap:.375rem;font-size:.8125rem;cursor:pointer}.tool-checkbox input[type=checkbox]{cursor:pointer}.ma-predictor-controls{margin-top:.375rem;padding-top:.375rem;border-top:1px solid #e5e7eb}.ma-predictor-controls label{display:block;font-size:.6875rem;font-weight:500;color:#6b7280;margin-bottom:.25rem}.predictor-range-inputs{display:flex;justify-content:space-between;gap:.375rem;margin-bottom:.25rem}.predictor-range-group{display:flex;align-items:center;gap:.25rem}.predictor-range-group label{font-size:.625rem;font-weight:600;color:#64748b;margin-bottom:0}.predictor-range-input{width:60px;padding:.1875rem .25rem;border:1px solid #cbd5e1;border-radius:3px;font-size:.6875rem;text-align:right;background:white}.predictor-range-input:focus{outline:none;border-color:#9c27b0;box-shadow:0 0 0 2px #9c27b01a}.price-predictor-slider{width:100%;margin:.25rem 0;cursor:pointer}.predicted-price-display{display:block;font-size:.75rem;font-weight:600;color:#9c27b0;text-align:center;margin-top:.125rem}.indicators-panel{background:white;padding:.5rem .625rem;border-radius:6px;box-shadow:0 1px 2px #0000000f;margin-bottom:0}.indicators-panel h3{margin:0 0 .375rem;font-size:.8125rem;color:#1e293b}.indicators-checkboxes{display:flex;gap:1rem;flex-wrap:wrap}.indicator-checkbox{display:flex;align-items:center;gap:.375rem;cursor:pointer;font-size:.75rem;color:#475569;-webkit-user-select:none;user-select:none}.indicator-checkbox input[type=checkbox]{width:14px;height:14px;cursor:pointer;accent-color:#2563eb}.indicator-checkbox span{font-weight:500}.orders-panel,.positions-panel,.transactions-panel,.pending-orders-panel{background:white;padding:.5rem .625rem;border-radius:6px;box-shadow:0 1px 2px #0000000f;font-size:.8125rem}.orders-panel h3,.positions-panel h3,.transactions-panel h3,.pending-orders-panel h3{margin:0 0 .5rem;font-size:.8125rem;color:#1e293b;border-bottom:1px solid #e2e8f0;padding-bottom:.375rem}.order-tabs{display:flex;gap:.5rem;margin-bottom:.75rem;border-bottom:2px solid #e2e8f0}.order-tab{padding:.5rem 1rem;border:none;background:transparent;color:#6b7280;font-size:.875rem;font-weight:500;cursor:pointer;border-bottom:2px solid transparent;margin-bottom:-2px;transition:all .2s}.order-tab:hover{color:#2563eb}.order-tab.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}.new-order-form{display:flex;flex-direction:column;gap:.5rem;margin-bottom:.5rem;padding-bottom:.5rem;border-bottom:1px solid #e2e8f0}.order-type-section{display:flex;flex-direction:column;gap:.375rem;padding:.5rem;background:#f8f9fa;border-radius:4px;border:1px solid #e2e8f0}.order-type-section h4{margin:0;font-size:.75rem;color:#1e293b;font-weight:600}.order-help-text{margin:0 0 .25rem;font-size:.6875rem;color:#64748b;font-style:italic}.order-divider{text-align:center;font-weight:600;color:#64748b;font-size:.875rem;position:relative}.order-divider:before,.order-divider:after{content:"";position:absolute;top:50%;width:40%;height:1px;background:#e2e8f0}.order-divider:before{left:0}.order-divider:after{right:0}.form-row,.form-row-inline{display:flex;align-items:center;gap:.375rem;flex-wrap:wrap}.form-field{display:flex;align-items:center;gap:.1875rem}.form-field label{font-size:.6875rem;font-weight:600;color:#475569;white-space:nowrap}.input-field-sm{width:55px;padding:.25rem .375rem;border:1px solid #cbd5e1;border-radius:3px;font-size:.75rem}.input-field-sm:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 2px #2563eb1a}.new-order-form.compact{gap:.375rem;margin-bottom:.5rem;padding-bottom:.5rem}.new-order-form.compact .order-help-text{font-size:.75rem;margin-bottom:.25rem}.form-row.compact{gap:.375rem;margin-bottom:0}.form-row.compact label{min-width:50px;font-size:.8125rem}.buy-at-close-btn.compact,.short-now-btn.compact,.add-order-btn.compact,.add-short-order-btn.compact{padding:.375rem .75rem;font-size:.75rem;white-space:nowrap}.checkbox-label-compact{display:flex;align-items:center;gap:.25rem;font-size:.75rem;color:#475569;cursor:pointer}.checkbox-label-compact input[type=checkbox]{cursor:pointer;width:14px;height:14px;accent-color:#2563eb}.checkbox-label-compact span{font-weight:500}.shares-hint{font-size:.75rem;color:#64748b;font-style:italic;margin-left:.25rem}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#475569;cursor:pointer;margin-left:.5rem;-webkit-user-select:none;user-select:none}.checkbox-label input[type=checkbox]{cursor:pointer;width:18px;height:18px;accent-color:#2563eb}.checkbox-label span{font-weight:500}.checkbox-label{display:flex;align-items:center;gap:.5rem;font-size:.875rem;color:#475569;cursor:pointer;margin-left:.5rem}.checkbox-label input[type=checkbox]{cursor:pointer;width:1rem;height:1rem}.form-row label{font-size:.875rem;font-weight:600;color:#475569;min-width:80px}.input-field{flex:1;padding:.5rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.875rem}.input-field.small{flex:1;padding:.375rem;font-size:.8125rem}.input-field:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.buy-at-close-section{margin-bottom:.375rem;padding-bottom:.375rem;border-bottom:1px solid #e2e8f0}.buy-at-close-btn{background:#10b981;color:#fff;border:none;padding:.375rem .75rem;border-radius:4px;font-weight:600;cursor:pointer;transition:background .2s;width:100%;font-size:.75rem}.buy-at-close-btn:hover{background:#059669}.add-order-btn{background:#2563eb;color:#fff;border:none;padding:.375rem .5rem;border-radius:4px;font-weight:600;font-size:.75rem;cursor:pointer;transition:background .2s;margin-top:.25rem}.add-order-btn:hover{background:#1d4ed8}.orders-list,.positions-list,.transactions-list{display:flex;flex-direction:column;gap:.375rem;max-height:400px;overflow-y:auto}.order-item,.position-item{border:1px solid #e2e8f0;border-radius:4px;padding:.5rem;background:#f8f9fa}.order-header,.position-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:.25rem;font-weight:600;font-size:.8125rem;color:#1e293b}.delete-btn{background:#ef4444;color:#fff;border:none;width:24px;height:24px;border-radius:4px;cursor:pointer;font-size:1.2rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s}.delete-btn:hover{background:#dc2626}.delete-order-btn{background:#ef4444;color:#fff;border:none;width:20px;height:20px;border-radius:4px;cursor:pointer;font-size:1rem;line-height:1;display:flex;align-items:center;justify-content:center;transition:background .2s;padding:0;margin-left:auto}.delete-order-btn:hover{background:#dc2626}.order-details,.position-details{display:flex;flex-direction:column;gap:.125rem;font-size:.75rem;color:#475569}.position-pnl{font-weight:600;margin-top:.25rem}.position-controls{margin-top:.375rem;padding-top:.375rem;border-top:1px solid #e2e8f0;display:flex;flex-direction:column;gap:.25rem}.sell-now-btn{background:#10b981;color:#fff;border:none;padding:.375rem .5rem;border-radius:4px;font-weight:600;font-size:.75rem;cursor:pointer;transition:background .2s}.sell-now-btn:hover{background:#059669}.sell-at-close-btn{background:#3b82f6;color:#fff;border:none;padding:.375rem .5rem;border-radius:4px;font-weight:600;font-size:.75rem;cursor:pointer;transition:background .2s}.sell-at-close-btn:hover{background:#2563eb}.control-row{display:flex;align-items:center;gap:.375rem}.control-row label{font-size:.75rem;font-weight:600;color:#475569;min-width:45px}.empty-state{text-align:center;padding:.75rem;color:#94a3b8;font-size:.75rem}.transaction-item{border:1px solid #e2e8f0;border-radius:6px;padding:.75rem;border-left:4px solid}.transaction-item.profit{background:#f0fdf4;border-color:#10b981}.transaction-item.loss{background:#fef2f2;border-color:#ef4444}.transaction-header{font-weight:600;font-size:.875rem;color:#1e293b;margin-bottom:.5rem}.transaction-details{display:flex;flex-wrap:wrap;gap:.75rem;font-size:.8125rem;color:#475569;margin-bottom:.5rem}.reason-badge{background:#e2e8f0;padding:.25rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600}.transaction-pnl{font-weight:600;font-size:.875rem}.transaction-item.profit .transaction-pnl{color:#10b981}.transaction-item.loss .transaction-pnl{color:#ef4444}.game-summary{background:white;padding:2rem;border-radius:8px;box-shadow:0 1px 3px #00000014;display:flex;flex-direction:column;align-items:center;width:100%}.game-summary>*{width:100%}.game-summary>.restart-btn{width:auto;max-width:300px}.game-summary h2{margin:0 0 1.5rem;font-size:1.5rem;color:#1e293b}.summary-stats{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1.5rem;margin-bottom:2rem;padding:1.5rem;background:#f8f9fa;border-radius:8px}.summary-stat{display:flex;flex-direction:column;gap:.5rem}.summary-label{font-weight:600;color:#64748b;font-size:.875rem}.summary-value{font-size:1.5rem;font-weight:700;color:#1e293b}.summary-value.profit{color:#10b981}.summary-value.loss{color:#ef4444}.summary-transactions{margin-bottom:2rem}.summary-transactions h3{margin:0 0 1rem;font-size:1.125rem;color:#1e293b}.transactions-table{display:flex;flex-direction:column;border:1px solid #e2e8f0;border-radius:6px;overflow:hidden}.table-header{display:grid;grid-template-columns:repeat(8,1fr);gap:1rem;padding:.75rem 1rem;background:#f8f9fa;font-weight:600;font-size:.875rem;color:#475569;border-bottom:2px solid #e2e8f0}.table-row{display:grid;grid-template-columns:repeat(8,1fr);gap:1rem;padding:.75rem 1rem;border-bottom:1px solid #e2e8f0;font-size:.875rem;align-items:center}.table-row:last-child{border-bottom:none}.table-row:hover{background:#f8f9fa}.new-game-btn{background:#2563eb;color:#fff;border:none;padding:.75rem 2rem;border-radius:6px;font-weight:600;font-size:1rem;cursor:pointer;transition:background .2s}.new-game-btn:hover{background:#1d4ed8}@media (max-width: 1200px){.game-layout{grid-template-columns:1fr}.game-sidebar{order:-1}}.searchable-stock-select{position:relative;min-width:200px}.stock-select-button{display:flex;align-items:center;justify-content:space-between;width:100%;padding:.5rem .75rem;border:1px solid #cbd5e1;border-radius:6px;font-size:.875rem;background:white;cursor:pointer;text-align:left;transition:border-color .2s,box-shadow .2s}.stock-select-button:hover{border-color:#94a3b8}.stock-select-button:focus{outline:none;border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.stock-select-value{display:flex;align-items:center;gap:.25rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-name-hint{color:#64748b;font-size:.8rem;overflow:hidden;text-overflow:ellipsis}.stock-select-arrow{color:#64748b;font-size:.65rem;margin-left:.5rem;flex-shrink:0}.stock-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:white;border:1px solid #e2e8f0;border-radius:8px;box-shadow:0 10px 40px #00000026;z-index:1000;max-height:400px;display:flex;flex-direction:column;min-width:300px}.stock-search-container{padding:.75rem;border-bottom:1px solid #e2e8f0;display:flex;gap:.5rem}.stock-search-input{flex:1;padding:.5rem .75rem;border:1px solid #e2e8f0;border-radius:6px;font-size:.875rem;font-family:SF Mono,Monaco,Inconsolata,monospace;font-weight:600;text-transform:uppercase;outline:none;transition:border-color .2s,box-shadow .2s}.stock-search-input:focus{border-color:#2563eb;box-shadow:0 0 0 3px #2563eb1a}.stock-search-input::placeholder{color:#94a3b8;font-weight:400;text-transform:none}.stock-confirm-btn{padding:.5rem 1rem;background:#2563eb;color:#fff;border:none;border-radius:6px;font-size:.875rem;font-weight:600;cursor:pointer;transition:background .2s}.stock-confirm-btn:hover:not(:disabled){background:#1d4ed8}.stock-confirm-btn:disabled{background:#cbd5e1;cursor:not-allowed}.stock-list{list-style:none;margin:0;padding:0;overflow-y:auto;max-height:320px}.stock-list-header{padding:.5rem .75rem;font-size:.7rem;font-weight:600;color:#64748b;text-transform:uppercase;letter-spacing:.05em;background:#f8fafc;border-bottom:1px solid #e2e8f0;position:sticky;top:0}.stock-list-item{display:flex;align-items:center;gap:.75rem;padding:.6rem .75rem;cursor:pointer;transition:background .15s;border-bottom:1px solid #f1f5f9}.stock-list-item:hover,.stock-list-item.highlighted{background:#f1f5f9}.stock-list-item.selected{background:#eff6ff}.stock-list-item.selected .stock-symbol{color:#2563eb}.stock-symbol{font-weight:600;color:#1e293b;min-width:60px;font-family:SF Mono,Monaco,Inconsolata,monospace}.stock-name{color:#64748b;font-size:.8rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.stock-list-empty{padding:1.5rem;text-align:center;color:#94a3b8;font-size:.875rem}.stock-list-hint{padding:.75rem;text-align:center;color:#64748b;font-size:.75rem;background:#f8fafc;border-top:1px solid #e2e8f0}.order-direction-selector{display:flex;gap:3px;padding:4px;background:#f1f5f9;border-radius:4px;margin-bottom:.375rem}.direction-btn{flex:1;padding:4px 8px;border:none;border-radius:3px;font-size:.75rem;font-weight:600;cursor:pointer;background:transparent;color:#64748b;transition:all .2s}.direction-btn:hover{background:#e2e8f0}.direction-btn.active.buy{background:#10b981;color:#fff}.direction-btn.active.short{background:#ef4444;color:#fff}.short-now-btn{width:100%;padding:.375rem .5rem;background:#ef4444;color:#fff;border:none;border-radius:4px;font-weight:600;font-size:.75rem;cursor:pointer;transition:background .2s;margin-top:.25rem}.short-now-btn:hover{background:#dc2626}.add-short-order-btn{width:100%;padding:.375rem .5rem;background:#ef4444;color:#fff;border:none;border-radius:4px;font-weight:600;font-size:.75rem;cursor:pointer;transition:background .2s;margin-top:.25rem}.add-short-order-btn:hover{background:#dc2626}.order-type-badge{display:inline-block;padding:2px 6px;border-radius:4px;font-size:.65rem;font-weight:700;text-transform:uppercase;letter-spacing:.5px}.order-type-badge.long{background:#d1fae5;color:#059669}.order-type-badge.short{background:#fee2e2;color:#dc2626}.position-item.short-order,.position-item.short-position{border-left:3px solid #ef4444}.position-item.long-order,.position-item.long-position{border-left:3px solid #10b981}.cover-now-btn{width:100%;padding:.375rem .5rem;background:#ef4444;color:#fff;border:none;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .2s}.cover-now-btn:hover:not(:disabled){background:#dc2626}.cover-now-btn:disabled{opacity:.5;cursor:not-allowed}.cover-at-close-btn{width:100%;padding:.375rem .5rem;background:#fca5a5;color:#991b1b;border:none;border-radius:4px;font-size:.75rem;font-weight:600;cursor:pointer;transition:background .2s}.cover-at-close-btn:hover:not(:disabled){background:#f87171;color:#fff}.cover-at-close-btn:disabled{opacity:.5;cursor:not-allowed}.intraday-note{background:#fef3c7;color:#92400e;padding:2px 6px;border-radius:3px;font-size:.6875rem;margin:2px 0}.transaction-item.short-trade{border-left:3px solid #ef4444}.transaction-item.long-trade{border-left:3px solid #10b981}.transaction-header{display:flex;align-items:center;gap:4px}.sell-now-btn:disabled,.sell-at-close-btn:disabled{opacity:.5;cursor:not-allowed}.custom-ma-page .controls-panel{margin-bottom:3rem}.custom-ma-page .strategy-description-banner{margin-top:2rem;margin-bottom:2rem}.controls-panel-subtitle{color:#666;font-size:14px;margin-top:5px;margin-bottom:20px}.custom-ma-page .controls-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(280px,1fr));gap:20px;align-items:start}.custom-ma-page .control-group{display:flex;flex-direction:column;gap:8px}.custom-ma-page .control-group label{font-weight:600;color:#333;font-size:14px;margin-bottom:4px}.stock-selector-wrapper{margin-bottom:10px}.pinned-stocks{display:flex;align-items:center;gap:8px;flex-wrap:wrap;margin-top:8px}.pinned-label{font-size:12px;color:#666;font-weight:500}.pinned-stock-btn{padding:6px 12px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;font-size:13px;font-weight:500;transition:all .2s ease}.pinned-stock-btn:hover{background:#f0f0f0;border-color:#2563eb}.pinned-stock-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.input-with-unit{display:flex;align-items:stretch;gap:0;width:100%}.number-input{flex:1;padding:10px 12px;border:1px solid #ddd;border-radius:4px 0 0 4px;font-size:14px;min-width:0;height:42px}.number-input:focus{outline:none;border-color:#2563eb;position:relative;z-index:1}.input-unit{display:flex;align-items:center;padding:10px 16px;background:#f8f9fa;border:1px solid #ddd;border-left:none;border-radius:0 4px 4px 0;font-size:14px;color:#666;white-space:nowrap;min-width:fit-content;height:42px}.custom-ma-page .select-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;background:white;height:42px;cursor:pointer}.custom-ma-page .select-input:focus{outline:none;border-color:#2563eb}.custom-ma-page .run-button{width:100%;margin-top:22px;height:42px}.input-hint{font-size:12px;color:#888;margin-top:-4px;line-height:1.4}.loading-details{font-size:14px;color:#666;margin-top:8px}.custom-ma-page .searchable-stock-select{width:100%;position:relative}.custom-ma-page .stock-select-button{width:100%;display:flex;justify-content:space-between;align-items:center;padding:10px 12px;border:1px solid #ddd;background:white;border-radius:4px;cursor:pointer;font-size:14px;transition:all .2s ease;height:42px;text-align:left}.custom-ma-page .stock-select-button:hover{border-color:#2563eb}.custom-ma-page .stock-select-value{display:flex;align-items:center}.custom-ma-page .stock-dropdown{position:absolute;top:100%;left:0;right:0;margin-top:4px;background:white;border:1px solid #ddd;border-radius:4px;box-shadow:0 4px 6px #0000001a;z-index:1000;max-height:400px;overflow-y:auto}.custom-ma-page .control-group:first-child{grid-column:1 / -1}.trade-type-selection{grid-column:1 / -1;padding:16px;background:#f8f9fa;border-radius:6px;border:1px solid #e2e8f0}.checkbox-group{display:flex;gap:24px;margin-top:12px}.checkbox-label{display:flex;align-items:center;gap:8px;cursor:pointer;font-size:14px;font-weight:500;color:#1e293b}.checkbox-label input[type=checkbox]{width:18px;height:18px;cursor:pointer;accent-color:#2563eb}.checkbox-label span{-webkit-user-select:none;user-select:none}.checkbox-label:hover{color:#2563eb}.slippage-toggle{grid-column:1 / -1;padding-top:1rem;border-top:1px solid #e2e8f0;margin-top:.5rem}.slippage-checkbox{padding:.75rem 1rem;background:#f8fafc;border-radius:8px;border:1px solid #e2e8f0;transition:all .2s ease}.slippage-checkbox:hover{background:#f1f5f9;border-color:#cbd5e1}.slippage-checkbox input:checked+span{color:#2563eb;font-weight:600}.limit-order-input{background:#fefce8;padding:1rem;border-radius:8px;border:1px solid #fef08a}.limit-order-input label{color:#854d0e}.limit-order-input .input-hint{color:#a16207}.duration-mode-group{grid-column:1 / -1}.duration-mode-toggle{display:flex;gap:0;margin-bottom:12px}.mode-btn{flex:1;padding:10px 16px;border:1px solid #ddd;background:white;cursor:pointer;font-size:14px;font-weight:500;color:#666;transition:all .2s ease}.mode-btn:first-child{border-radius:6px 0 0 6px;border-right:none}.mode-btn:last-child{border-radius:0 6px 6px 0}.mode-btn:hover:not(.active){background:#f0f0f0}.mode-btn.active{background:#2563eb;color:#fff;border-color:#2563eb}.date-range-inputs{display:flex;gap:12px;margin-bottom:8px}.date-input-group{flex:1;display:flex;flex-direction:column;gap:4px}.date-input-group label{font-size:12px;font-weight:500;color:#666}.date-input{width:100%;padding:10px 12px;border:1px solid #ddd;border-radius:4px;font-size:14px;height:42px;cursor:pointer}.date-input:focus{outline:none;border-color:#2563eb}.date-range-span{display:flex;align-items:center;gap:8px;padding:8px 12px;background:#f0f9ff;border:1px solid #bae6fd;border-radius:6px;margin-bottom:8px}.span-label{font-size:13px;color:#0369a1;font-weight:500}.span-value{font-size:14px;color:#0c4a6e;font-weight:600}.api-warning{display:flex;align-items:center;gap:8px;padding:10px 12px;border-radius:6px;font-size:13px;margin-bottom:8px}.api-warning.warning{background:#fef3c7;border:1px solid #f59e0b;color:#92400e}.api-warning.error{background:#fee2e2;border:1px solid #ef4444;color:#b91c1c}.warning-icon{font-size:16px}*{margin:0;padding:0;box-sizing:border-box}body{font-family:-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,Oxygen,Ubuntu,Cantarell,Fira Sans,Droid Sans,Helvetica Neue,sans-serif;-webkit-font-smoothing:antialiased;-moz-osx-font-smoothing:grayscale;background-color:#f5f5f5}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}#root{min-height:100vh}
