.system-health{min-height:200px}.health-loading{color:#999;font-style:italic}.health-content{display:flex;flex-direction:column;gap:12px}.health-status{display:flex;align-items:center;gap:8px;padding:8px 12px;border-radius:4px;font-weight:600}.health-status-healthy{background-color:#d4edda;color:#155724}.health-status-degraded{background-color:#fff3cd;color:#856404}.health-status-error{background-color:#f8d7da;color:#721c24}.status-label{font-weight:500}.health-metric{display:flex;flex-direction:column;gap:4px;padding:8px 0;border-bottom:1px solid #e5e5e5}.health-metric:last-child{border-bottom:none}.metric-value{font-size:16px;color:#1a1a1a;font-family:monospace}.metric-subtext{font-size:12px;color:#999;font-style:italic}.health-warnings{margin-top:8px;padding:12px;background-color:#fff3cd;border-radius:4px;border-left:4px solid #ffc107}.warnings-title{font-weight:600;margin-bottom:8px;color:#856404}.warning-item{font-size:14px;color:#856404;margin-bottom:4px}.warning-item:last-child{margin-bottom:0}.health-configuration{margin-top:20px;padding-top:20px;border-top:1px solid #e0e0e0}.config-section{margin-bottom:16px}.config-title{font-weight:600;font-size:.95em;color:#555;margin-bottom:8px}.config-value{display:flex;flex-wrap:wrap;gap:8px}.edge-badge{display:inline-block;padding:4px 12px;background-color:#e3f2fd;color:#1976d2;border-radius:12px;font-size:.85em;font-weight:500}.config-list{display:flex;flex-direction:column;gap:6px}.config-item{display:flex;align-items:flex-start;gap:12px;font-size:.9em}.config-label{font-weight:500;color:#666;min-width:120px}.config-desc{color:#333;flex:1}@media (max-width: 768px){.system-health{min-height:auto}.system-health h2{font-size:16px;margin-bottom:10px}.health-content{gap:8px}.health-status{padding:6px 10px;font-size:13px}.health-metric{padding:5px 0}.metric-label{font-size:12px}.metric-value{font-size:13px}.metric-subtext{font-size:10px}.health-warnings{padding:8px;margin-top:6px}.warnings-title{font-size:12px;margin-bottom:5px}.warning-item{font-size:11px}}@media (max-width: 480px){.health-status{font-size:12px;padding:5px 8px}.metric-value{font-size:12px}.config-item{flex-direction:column;gap:4px}.config-label{min-width:auto}}.portfolio-state{min-height:200px}.state-loading{color:#999;font-style:italic}.state-content{display:flex;flex-direction:column;gap:12px}.position-row{display:flex;align-items:center;justify-content:space-between;padding:12px;background-color:#f8f9fa;border-radius:4px}.position-label{font-weight:600;color:#1a1a1a}.position-badge{padding:4px 12px;border-radius:4px;font-weight:600;font-size:14px;text-transform:uppercase}.position-flat{background-color:#e9ecef;color:#495057}.position-long{background-color:#d4edda;color:#155724}.position-short{background-color:#f8d7da;color:#721c24}.state-metric{display:flex;justify-content:space-between;align-items:center;padding:8px 0;border-bottom:1px solid #e5e5e5}.state-metric:last-child{border-bottom:none}.state-metric-total{margin-top:8px;padding-top:12px;border-top:2px solid #333}.metric-label{font-size:14px;color:#666;font-weight:500}.metric-value{font-size:16px;color:#1a1a1a;font-weight:600;font-family:monospace}.metric-value-large{font-size:18px}.metric-value.positive{color:#155724}.metric-value.negative{color:#721c24}@media (max-width: 768px){.portfolio-state{min-height:auto}.portfolio-state h2{font-size:16px;margin-bottom:10px}.state-content{gap:8px}.position-row{padding:8px}.position-label{font-size:13px}.position-badge{font-size:11px;padding:3px 8px}.state-metric{padding:5px 0}.metric-label{font-size:12px}.metric-value{font-size:13px}.metric-value-large{font-size:15px}.state-metric-total{margin-top:6px;padding-top:8px}}@media (max-width: 480px){.position-row{padding:6px}.metric-value-large{font-size:14px}}.signal-summary{min-height:300px}.summary-content{display:flex;flex-direction:column;gap:24px}.signal-distribution{padding:16px;background-color:#f8f9fa;border-radius:4px}.signal-distribution h3{font-size:16px;font-weight:600;margin-bottom:12px;color:#1a1a1a}.distribution-bars{display:flex;flex-direction:column;gap:12px}.bar-item{display:flex;align-items:center;gap:12px}.bar-label{min-width:60px;font-weight:500;font-size:14px;color:#333}.bar-container{flex:1;display:flex;align-items:center;gap:12px;position:relative;height:24px;background-color:#e9ecef;border-radius:4px;overflow:hidden}.bar{position:absolute;left:0;top:0;bottom:0;height:100%;transition:width .3s ease}.bar-positive{background-color:#d4edda}.bar-neutral{background-color:#e9ecef}.bar-negative{background-color:#f8d7da}.bar-value{position:absolute;right:8px;font-size:12px;font-weight:600;color:#333;z-index:1}@media (max-width: 768px){.signal-summary{min-height:auto}.signal-summary h2{font-size:16px;margin-bottom:10px}.summary-content{gap:12px}.signal-distribution{padding:10px}.signal-distribution h3{font-size:13px;margin-bottom:8px}.distribution-bars{gap:8px}.bar-item{gap:6px}.bar-label{min-width:45px;font-size:11px}.bar-container{height:18px}.bar-value{font-size:10px;right:5px}}@media (max-width: 480px){.signal-distribution h3{font-size:12px}.bar-label{min-width:40px;font-size:10px}.bar-value{font-size:9px}}.recent-trades{min-height:300px}.recent-trades h2{margin-top:0}.trades-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:16px}.trades-header h2{margin:0;border-bottom:none;padding-bottom:0}.expand-button{padding:6px 12px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;cursor:pointer;font-size:14px;color:#495057;font-weight:500;transition:background-color .2s}.expand-button:hover{background-color:#e9ecef}.expand-button:active{background-color:#dee2e6}.trades-empty{color:#999;font-style:italic;padding:20px;text-align:center}.trades-table-container{overflow-x:auto;max-height:600px;overflow-y:auto}.trades-table{width:100%;border-collapse:collapse;font-size:14px}@media (max-width: 768px){.recent-trades{min-height:auto}.trades-header{flex-direction:row;align-items:center;gap:8px;margin-bottom:12px}.trades-header h2{font-size:16px;margin:0;flex:1}.expand-button{font-size:12px;padding:6px 10px;min-height:32px}.trades-table-container{max-height:none;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -10px;padding:0 10px}.trades-table{font-size:11px;min-width:900px}.trades-table th,.trades-table td{padding:6px 4px;white-space:nowrap}.trades-table th{font-size:10px;padding:8px 4px}.timestamp-cell{font-size:10px}.side-badge,.status-badge{font-size:10px;padding:2px 5px}.price-cell,.pnl-cell{font-size:11px}.reason-cell{font-size:10px;max-width:100px}.bars-cell,.edge-cell{font-size:10px}}@media (max-width: 480px){.trades-table{font-size:10px;min-width:850px}.trades-table th,.trades-table td{padding:5px 3px}.trades-table th{font-size:9px;padding:6px 3px}}.trades-table thead{position:sticky;top:0;background-color:#f8f9fa;z-index:10}.trades-table th{padding:12px 8px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;white-space:nowrap}.trades-table td{padding:10px 8px;border-bottom:1px solid #e9ecef;white-space:nowrap}.trades-table tbody tr:hover{background-color:#f8f9fa}.trades-table tbody tr.trade-open{background-color:#e7f3ff;border-left:3px solid #2196F3}.trades-table tbody tr.trade-open:hover{background-color:#d0e7ff}.timestamp-cell{font-family:monospace;font-size:12px;color:#666}.side-badge{padding:4px 8px;border-radius:4px;font-weight:600;font-size:12px;text-transform:uppercase}.side-long{background-color:#d4edda;color:#155724}.side-short{background-color:#f8d7da;color:#721c24}.price-cell{font-family:monospace;text-align:right}.pnl-cell{font-family:monospace;font-weight:600;text-align:right}.pnl-cell.positive{color:#155724}.pnl-cell.negative{color:#721c24}.reason-cell{font-size:12px;color:#666;max-width:200px;overflow:hidden;text-overflow:ellipsis}.bars-cell{text-align:center;font-family:monospace}.edge-cell{font-size:12px;color:#666;font-family:monospace}.status-badge{padding:4px 8px;border-radius:4px;font-weight:600;font-size:12px;text-transform:uppercase;display:inline-block}.status-open{background-color:#e3f2fd;color:#1976d2}.status-closed{background-color:#f5f5f5;color:#666}.recent-decisions{min-height:300px}.recent-decisions h2{margin-top:0}.decisions-empty{color:#999;font-style:italic;padding:20px;text-align:center}.decisions-table-container{overflow-x:auto;max-height:600px;overflow-y:auto}.decisions-table{width:100%;border-collapse:collapse;font-size:14px}.decisions-table thead{position:sticky;top:0;background-color:#f8f9fa;z-index:10}.decisions-table th{padding:12px 8px;text-align:left;font-weight:600;color:#333;border-bottom:2px solid #dee2e6;white-space:nowrap}.decisions-table td{padding:10px 8px;border-bottom:1px solid #e9ecef}.decisions-table tbody tr:hover{background-color:#f8f9fa}.timestamp-cell{font-family:monospace;font-size:12px;color:#666;white-space:nowrap}.signal-badge{padding:4px 8px;border-radius:4px;font-weight:600;font-size:12px;text-transform:uppercase;display:inline-block}.signal-long{background-color:#d4edda;color:#155724}.signal-short{background-color:#f8d7da;color:#721c24}.signal-flat{background-color:#e9ecef;color:#495057}.reason-cell{font-size:12px;color:#666;max-width:500px;overflow:hidden;text-overflow:ellipsis}@media (max-width: 768px){.recent-decisions{min-height:auto}.recent-decisions h2{font-size:16px;margin-bottom:10px}.decisions-table-container{max-height:none;overflow-x:auto;-webkit-overflow-scrolling:touch;margin:0 -10px;padding:0 10px}.decisions-table{font-size:11px;min-width:650px}.decisions-table th,.decisions-table td{padding:6px 4px}.decisions-table th{font-size:10px;padding:8px 4px}.timestamp-cell{font-size:10px;white-space:nowrap}.signal-badge{font-size:10px;padding:2px 5px}.reason-cell{font-size:10px;max-width:150px}}@media (max-width: 480px){.decisions-table{font-size:10px;min-width:600px}.decisions-table th,.decisions-table td{padding:5px 3px}.decisions-table th{font-size:9px;padding:6px 3px}}.dashboard-mobile{width:100%;min-height:100vh;background-color:#f5f5f5;padding-bottom:20px}.dashboard-mobile-header{background:#fff;padding:12px 16px;display:flex;justify-content:space-between;align-items:center;border-bottom:1px solid #e5e5e5;position:sticky;top:0;z-index:100}.dashboard-mobile-header h1{font-size:18px;font-weight:600;margin:0;color:#1a1a1a}.logout-button-mobile{padding:6px 12px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;color:#495057;font-size:13px;font-weight:500;cursor:pointer}.logout-button-mobile:active{background-color:#e9ecef}.mobile-stats-bar{background:#fff;padding:16px;display:flex;justify-content:space-around;border-bottom:1px solid #e5e5e5;margin-bottom:8px}.mobile-stat-item{flex:1;text-align:center;padding:0 8px}.mobile-stat-item:not(:last-child){border-right:1px solid #e5e5e5}.stat-label{font-size:11px;color:#666;text-transform:uppercase;letter-spacing:.5px;margin-bottom:4px;font-weight:500}.stat-value{font-size:16px;font-weight:600;color:#1a1a1a;font-family:monospace}.stat-value.positive{color:#155724}.stat-value.negative{color:#721c24}.stat-value.status-healthy{color:#155724}.stat-value.status-degraded{color:#856404}.stat-value.status-error{color:#721c24}.mobile-tabs{background:#fff;display:flex;border-bottom:2px solid #e5e5e5;margin-bottom:8px;position:sticky;top:49px;z-index:99}.mobile-tab{flex:1;padding:14px 8px;background:none;border:none;border-bottom:2px solid transparent;color:#666;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:-2px}.mobile-tab.active{color:#667eea;border-bottom-color:#667eea;font-weight:600}.mobile-tab:active{background-color:#f8f9fa}.mobile-content{padding:0 8px}.mobile-overview{display:flex;flex-direction:column;gap:8px}.mobile-section-card,.mobile-tab-content{background:#fff;border-radius:8px;padding:16px;box-shadow:0 1px 3px #0000001a}.mobile-section-card .dashboard-section,.mobile-tab-content .dashboard-section{background:transparent;padding:0;box-shadow:none;margin:0}.mobile-section-card h2,.mobile-tab-content h2{font-size:16px;margin-bottom:12px;padding-bottom:8px;border-bottom:2px solid #e5e5e5}.mobile-section-card .system-health,.mobile-section-card .portfolio-state,.mobile-section-card .signal-summary,.mobile-tab-content .recent-trades,.mobile-tab-content .recent-decisions{min-height:auto}.mobile-tab-content .recent-trades h2,.mobile-tab-content .recent-decisions h2{display:none}.runner-card{background:#fff;border-radius:8px;padding:16px;box-shadow:0 2px 4px #0000001a;transition:transform .2s,box-shadow .2s}.runner-card:hover{transform:translateY(-2px);box-shadow:0 4px 8px #00000026}.runner-card-header{display:flex;justify-content:space-between;align-items:center;margin-bottom:12px;padding-bottom:12px;border-bottom:1px solid #e5e7eb}.runner-card-title{margin:0;font-size:18px;font-weight:600;color:#111827}.runner-card-status{padding:4px 12px;border-radius:12px;font-size:12px;font-weight:600;color:#fff;text-transform:uppercase}.runner-card-content{display:flex;flex-direction:column;gap:12px}.runner-card-metrics{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.runner-card-metric{display:flex;flex-direction:column;gap:4px}.runner-card-metric-label{font-size:12px;color:#6b7280;font-weight:500}.runner-card-metric-value{font-size:16px;font-weight:600;color:#111827}.runner-card-error{color:#ef4444;font-size:14px;margin:0}.runner-card-warnings{font-size:12px;color:#f59e0b;padding:8px;background:#fef3c7;border-radius:4px;margin-top:8px}@media (max-width: 768px){.runner-card-metrics{grid-template-columns:1fr}}.overview-dashboard{padding:24px;max-width:1400px;margin:0 auto}.overview-header{margin-bottom:24px}.overview-header h1{margin:0 0 8px;font-size:28px;font-weight:700;color:#111827}.overview-subtitle{margin:0;color:#6b7280;font-size:14px}.overview-grid{display:grid;grid-template-columns:repeat(auto-fill,minmax(320px,1fr));gap:24px}@media (max-width: 768px){.overview-dashboard{padding:16px}.overview-grid{grid-template-columns:1fr;gap:16px}}.tabs-container{display:flex;gap:8px;border-bottom:2px solid #e5e7eb;margin-bottom:24px;padding:0}.tab-button{padding:12px 24px;background:transparent;border:none;border-bottom:3px solid transparent;color:#6b7280;font-size:14px;font-weight:500;cursor:pointer;transition:all .2s;margin-bottom:-2px}.tab-button:hover{color:#111827;background:#f9fafb}.tab-button.active{color:#2563eb;border-bottom-color:#2563eb;font-weight:600}@media (max-width: 768px){.tabs-container{overflow-x:auto;-webkit-overflow-scrolling:touch}.tab-button{padding:10px 16px;font-size:13px;white-space:nowrap}}.dashboard{width:100%}.dashboard-header{margin-bottom:30px;display:flex;justify-content:space-between;align-items:center}.dashboard-header h1{font-size:32px;font-weight:600;color:#1a1a1a;margin:0}.logout-button{padding:8px 16px;background-color:#f8f9fa;border:1px solid #dee2e6;border-radius:4px;color:#495057;font-size:14px;font-weight:500;cursor:pointer;transition:background-color .2s}.logout-button:hover{background-color:#e9ecef}.logout-button:active{background-color:#dee2e6}.dashboard-grid{display:grid;grid-template-columns:repeat(auto-fit,minmax(400px,1fr));gap:20px}.dashboard-section{background:#fff;border-radius:8px;padding:20px;box-shadow:0 2px 4px #0000001a}.dashboard-section-wide{grid-column:1 / -1}.dashboard-section h2{font-size:20px;font-weight:600;margin-bottom:16px;color:#1a1a1a;border-bottom:2px solid #e5e5e5;padding-bottom:8px}@media (max-width: 768px){.dashboard-grid{grid-template-columns:1fr;gap:12px}.dashboard-section{padding:12px}.dashboard-section h2{font-size:16px;margin-bottom:10px;padding-bottom:6px}.dashboard-header{flex-direction:row;align-items:center;gap:12px;margin-bottom:16px}.dashboard-header h1{font-size:20px;flex:1}.logout-button{font-size:12px;padding:6px 12px;min-height:32px}}@media (max-width: 480px){.dashboard-header h1{font-size:18px}.dashboard-section{padding:10px}.dashboard-section h2{font-size:15px}}.login-container{min-height:100vh;display:flex;align-items:center;justify-content:center;background:linear-gradient(135deg,#667eea,#764ba2);padding:20px}.login-box{background:#fff;border-radius:8px;padding:40px;width:100%;max-width:400px;box-shadow:0 10px 40px #0003}.login-box h1{font-size:28px;font-weight:600;color:#1a1a1a;margin:0 0 8px;text-align:center}.login-subtitle{text-align:center;color:#666;margin:0 0 32px;font-size:14px}.login-form{display:flex;flex-direction:column;gap:24px}.form-group{display:flex;flex-direction:column;gap:8px}.form-group label{font-size:14px;font-weight:500;color:#333}.form-group input{padding:12px;border:1px solid #ddd;border-radius:4px;font-size:16px;transition:border-color .2s}.form-group input:focus{outline:none;border-color:#667eea;box-shadow:0 0 0 3px #667eea1a}.form-group input:disabled{background-color:#f5f5f5;cursor:not-allowed}.error-message{padding:12px;background-color:#fee;border:1px solid #fcc;border-radius:4px;color:#c33;font-size:14px;text-align:center}.login-button{padding:12px;background:linear-gradient(135deg,#667eea,#764ba2);color:#fff;border:none;border-radius:4px;font-size:16px;font-weight:600;cursor:pointer;transition:opacity .2s,transform .1s}.login-button:hover:not(:disabled){opacity:.9;transform:translateY(-1px)}.login-button:active:not(:disabled){transform:translateY(0)}.login-button:disabled{opacity:.6;cursor:not-allowed}@media (max-width: 768px){.login-container{padding:12px}.login-box{padding:28px 20px}.login-box h1{font-size:22px}.login-subtitle{font-size:13px}}@media (max-width: 480px){.login-container{padding:8px}.login-box{padding:24px 16px}.login-box h1{font-size:20px}.login-subtitle{font-size:12px}.form-group input{font-size:16px;padding:10px}.login-button{padding:12px;font-size:15px}}.App{min-height:100vh;padding:20px;max-width:1600px;margin:0 auto}@media (max-width: 768px){.App{padding:8px}}*{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;color:#333}code{font-family:source-code-pro,Menlo,Monaco,Consolas,Courier New,monospace}@media (max-width: 768px){body{font-size:13px}button:not(.expand-button):not(.logout-button){min-height:44px;min-width:44px}input[type=text],input[type=password],input[type=email],textarea,select{font-size:16px}}@media (max-width: 480px){body{font-size:12px}}
