:root{--bg-primary: #0a0a0f;--bg-secondary: #12121a;--bg-tertiary: #1a1a25;--text-primary: #f0f0f5;--text-secondary: #9090a0;--accent-green: #22c55e;--accent-red: #ef4444;--accent-blue: #3b82f6;--accent-yellow: #eab308;--border-color: #2a2a3a}*{margin:0;padding:0;box-sizing:border-box}body{font-family:Inter,-apple-system,BlinkMacSystemFont,Segoe UI,Roboto,sans-serif;background-color:var(--bg-primary);color:var(--text-primary);line-height:1.6}.dashboard{display:flex;flex-direction:column;gap:16px;padding:16px;min-height:100vh}.main-grid{display:grid;grid-template-columns:1fr 1fr 320px;gap:16px;flex:1}.left-column,.middle-column,.right-column{display:flex;flex-direction:column;gap:16px}.header{display:flex;justify-content:space-between;align-items:center;padding:16px 24px;background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color)}.header h1{font-size:1.5rem;font-weight:700;background:linear-gradient(135deg,var(--accent-blue),var(--accent-green));-webkit-background-clip:text;-webkit-text-fill-color:transparent}.status-bar{display:flex;gap:24px}.status-item{display:flex;align-items:center;gap:8px}.status-dot{width:8px;height:8px;border-radius:50%;animation:pulse 2s infinite}.status-dot.connected{background:var(--accent-green)}.status-dot.disconnected{background:var(--accent-red)}@keyframes pulse{0%,to{opacity:1}50%{opacity:.5}}.panel{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);overflow:hidden}.panel-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;border-bottom:1px solid var(--border-color)}.panel-header h3{font-size:.875rem;font-weight:600}.panel-title{font-size:.875rem;font-weight:600;color:var(--text-secondary);text-transform:uppercase;letter-spacing:.05em}.panel-content{padding:16px}.chart-container{width:100%;height:300px}.orderbook{display:grid;grid-template-columns:1fr 1fr;gap:8px;font-size:.75rem;font-family:JetBrains Mono,monospace}.orderbook-side{display:flex;flex-direction:column;gap:2px}.orderbook-row{display:flex;justify-content:space-between;padding:4px 8px;border-radius:4px;position:relative}.orderbook-row.bid{background:#22c55e1a}.orderbook-row.ask{background:#ef44441a}.price{font-weight:600;z-index:1}.price.bid{color:var(--accent-green)}.price.ask{color:var(--accent-red)}.qty{color:var(--text-secondary);z-index:1}.pnl-grid{display:grid;grid-template-columns:repeat(2,1fr);gap:12px}.pnl-card,.pnl-item{background:var(--bg-tertiary);border-radius:8px;padding:12px}.pnl-label,.pnl-item .label{font-size:.7rem;color:var(--text-secondary);margin-bottom:4px;display:block}.pnl-value,.pnl-item .value{font-size:1rem;font-weight:700;font-family:JetBrains Mono,monospace}.positive{color:var(--accent-green)}.negative{color:var(--accent-red)}.agent-state{display:flex;flex-direction:column;gap:12px}.agent-metric{display:flex;justify-content:space-between;align-items:center}.agent-metric-label{color:var(--text-secondary);font-size:.875rem}.agent-metric-value{font-family:JetBrains Mono,monospace;font-weight:600}.action-badge{padding:4px 12px;border-radius:16px;font-size:.75rem;font-weight:700;text-transform:uppercase}.action-badge.long{background:#22c55e33;color:var(--accent-green)}.action-badge.short{background:#ef444433;color:var(--accent-red)}.action-badge.hold{background:#9090a033;color:var(--text-secondary)}.action-badge.close{background:#eab30833;color:var(--accent-yellow)}.training-panel{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);padding:16px}.training-panel .panel-header{display:flex;justify-content:space-between;align-items:center;padding:0 0 12px;border-bottom:1px solid var(--border-color);margin-bottom:16px}.status-badge{padding:4px 10px;border-radius:12px;font-size:.7rem;font-weight:600}.status-badge.running{background:#22c55e33;color:var(--accent-green)}.status-badge.idle{background:#9090a033;color:var(--text-secondary)}.progress-container{background:var(--bg-tertiary);border-radius:8px;height:24px;position:relative;overflow:hidden;margin-bottom:16px}.progress-bar{height:100%;background:linear-gradient(90deg,var(--accent-blue),var(--accent-green));transition:width .3s ease}.progress-text{position:absolute;top:50%;left:50%;transform:translate(-50%,-50%);font-size:.7rem;font-weight:600;color:var(--text-primary);text-shadow:0 1px 2px rgba(0,0,0,.5)}.metrics-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:8px;margin-bottom:16px}.metrics-grid .metric{background:var(--bg-tertiary);padding:8px;border-radius:6px;text-align:center}.metrics-grid .metric .label{font-size:.6rem;color:var(--text-secondary);display:block}.metrics-grid .metric .value{font-size:.875rem;font-weight:600;font-family:JetBrains Mono,monospace}.config-form{display:flex;flex-direction:column;gap:12px;margin-bottom:16px}.form-group{display:flex;flex-direction:column;gap:4px}.form-group label{font-size:.7rem;color:var(--text-secondary)}.form-group input,.form-group select{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:6px;padding:8px 12px;color:var(--text-primary);font-size:.875rem}.form-group input:focus,.form-group select:focus{outline:none;border-color:var(--accent-blue)}.controls{display:flex;gap:8px}.btn-start,.btn-stop{flex:1;padding:12px;border:none;border-radius:8px;font-weight:600;cursor:pointer;transition:all .2s}.btn-start{background:var(--accent-green);color:#fff}.btn-start:hover{background:#1fa855}.btn-stop{background:var(--accent-red);color:#fff}.btn-stop:hover{background:#dc2626}.error-message{background:#ef44441a;border:1px solid var(--accent-red);color:var(--accent-red);padding:8px 12px;border-radius:6px;font-size:.75rem;margin-bottom:12px;display:flex;justify-content:space-between;align-items:center}.error-message button{background:none;border:none;color:var(--accent-red);cursor:pointer;font-size:1rem}.shadow-panel{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);padding:16px}.shadow-panel .panel-header{display:flex;justify-content:space-between;align-items:center;padding:0 0 12px;border-bottom:1px solid var(--border-color);margin-bottom:16px}.connection-status{font-size:.7rem;font-weight:500}.current-signal{display:flex;align-items:center;gap:16px;margin-bottom:16px}.signal-badge{padding:8px 20px;border-radius:8px;font-weight:700;font-size:.875rem;color:#fff}.signal-details{display:flex;gap:16px}.signal-details .detail{display:flex;flex-direction:column}.signal-details .label{font-size:.6rem;color:var(--text-secondary)}.signal-details .value{font-size:.75rem;font-family:JetBrains Mono,monospace}.signal-history{margin-top:16px}.history-header{font-size:.7rem;color:var(--text-secondary);margin-bottom:8px}.history-list{max-height:150px;overflow-y:auto}.signal-item{display:flex;justify-content:space-between;padding:4px 0;font-size:.7rem;border-bottom:1px solid var(--border-color)}.signal-item:last-child{border-bottom:none}.no-signals{color:var(--text-secondary);font-size:.75rem;text-align:center;padding:16px}.log-viewer{background:var(--bg-secondary);border-radius:12px;border:1px solid var(--border-color);transition:all .3s ease}.log-viewer.collapsed{max-height:48px}.log-viewer.expanded{max-height:400px}.log-header{display:flex;justify-content:space-between;align-items:center;padding:12px 16px;cursor:pointer;border-bottom:1px solid var(--border-color)}.log-title{font-size:.875rem;font-weight:600}.toggle-icon{font-size:.75rem;color:var(--text-secondary)}.log-toolbar{display:flex;justify-content:space-between;align-items:center;padding:8px 16px;border-bottom:1px solid var(--border-color);flex-wrap:wrap;gap:8px}.service-tabs{display:flex;gap:4px}.service-tabs button{padding:4px 10px;border:none;background:var(--bg-tertiary);color:var(--text-secondary);border-radius:4px;font-size:.7rem;cursor:pointer;transition:all .2s}.service-tabs button.active{background:var(--accent-blue);color:#fff}.log-filters{display:flex;gap:8px;align-items:center}.log-filters select,.log-filters input{background:var(--bg-tertiary);border:1px solid var(--border-color);border-radius:4px;padding:4px 8px;color:var(--text-primary);font-size:.7rem}.log-filters button{background:var(--bg-tertiary);border:none;padding:4px 8px;border-radius:4px;cursor:pointer}.log-filters button.active{background:var(--accent-blue)}.log-content{height:250px;overflow-y:auto;padding:8px 16px;font-family:JetBrains Mono,monospace;font-size:.7rem}.log-entry{padding:2px 0;display:flex;gap:8px}.log-time{color:var(--text-secondary);flex-shrink:0}.log-level{font-weight:600;flex-shrink:0;min-width:50px}.log-service{color:var(--accent-blue);flex-shrink:0}.log-message{color:var(--text-primary);word-break:break-all}.no-logs{text-align:center;color:var(--text-secondary);padding:32px}@media(max-width:1400px){.main-grid{grid-template-columns:1fr 1fr}.right-column{grid-column:1 / -1;flex-direction:row}.right-column>*{flex:1}}@media(max-width:1024px){.main-grid{grid-template-columns:1fr}.right-column{flex-direction:column}}
