*,*:before,*:after{box-sizing:border-box;margin:0;padding:0}:root{--bg: #0f1117;--surface: #1c1f2e;--border: #2d3148;--text: #e2e8f0;--muted: #8892a4;--green: #22c55e;--red: #ef4444;--yellow: #f59e0b;--blue: #3b82f6;--accent: #6366f1;font-family:Inter,system-ui,sans-serif;font-size:14px;color:var(--text);background:var(--bg)}body{min-height:100vh;background:var(--bg)}.login-container{display:flex;align-items:center;justify-content:center;min-height:100vh;background:var(--bg)}.login-form{background:var(--surface);border:1px solid var(--border);border-radius:12px;padding:2.5rem 2rem;width:100%;max-width:360px;display:flex;flex-direction:column;gap:1.2rem}.login-form h1{text-align:center;font-size:1.5rem}.login-form .subtitle{text-align:center;color:var(--muted);font-size:.85rem;margin-top:-.8rem}.form-group{display:flex;flex-direction:column;gap:.4rem}.form-group label{font-size:.8rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.form-group input{background:var(--bg);border:1px solid var(--border);border-radius:6px;color:var(--text);padding:.55rem .75rem;font-size:.9rem;width:100%;outline:none;transition:border-color .2s}.form-group input:focus{border-color:var(--accent)}.input-row{display:flex;gap:.4rem;align-items:center}.input-row input{flex:1}button{border:none;border-radius:6px;padding:.55rem 1.1rem;font-size:.875rem;font-weight:600;cursor:pointer;transition:opacity .15s}button:hover:not(:disabled){opacity:.85}button:disabled{opacity:.45;cursor:not-allowed}button[type=submit],.btn-primary{background:var(--accent);color:#fff;width:100%}.btn-success{background:var(--green);color:#000}.btn-danger{background:var(--red);color:#fff}.btn-secondary{background:var(--surface);border:1px solid var(--border);color:var(--text)}.btn-outline{background:transparent;border:1px solid var(--border);color:var(--muted)}.btn-icon{background:transparent;border:1px solid var(--border);padding:.45rem .65rem;color:var(--muted)}.error{color:var(--red);font-size:.85rem}.success-msg{color:var(--green);font-size:.85rem}.header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.5rem;border-bottom:1px solid var(--border);background:var(--surface)}.header h1{font-size:1.2rem}.header-actions{display:flex;gap:.5rem}.dashboard{max-width:1200px;margin:0 auto}.cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(200px,1fr));gap:1rem;padding:1.5rem}.card{background:var(--surface);border:1px solid var(--border);border-radius:10px;padding:1.2rem;display:flex;flex-direction:column;gap:.6rem}.card-title{font-size:.75rem;font-weight:600;color:var(--muted);text-transform:uppercase;letter-spacing:.06em}.card-value{font-size:1.6rem;font-weight:700}.status-card.running{border-color:var(--green)}.status-card.paused{border-color:var(--yellow)}.status-badge{font-size:1rem;font-weight:600}.section{padding:0 1.5rem 2rem}.section h2{font-size:1rem;margin-bottom:1rem;color:var(--muted);text-transform:uppercase;letter-spacing:.05em}.table-wrapper{overflow-x:auto;border-radius:8px;border:1px solid var(--border)}table{width:100%;border-collapse:collapse}th,td{padding:.65rem .85rem;text-align:left;font-size:.85rem}th{background:var(--surface);color:var(--muted);font-weight:600;border-bottom:1px solid var(--border)}td{border-bottom:1px solid var(--border)}tr:last-child td{border-bottom:none}tr:hover td{background:#ffffff05}.long{color:var(--green);font-weight:700}.short{color:var(--red);font-weight:700}.pnl-pos{color:var(--green);font-weight:600}.pnl-neg{color:var(--red);font-weight:600}.badge{padding:.15rem .5rem;border-radius:4px;font-size:.75rem;font-weight:600;text-transform:uppercase}.badge.open{background:#22c55e26;color:var(--green)}.badge.closed{background:#94a3b81f;color:var(--muted)}.badge.failed{background:#ef444426;color:var(--red)}.empty{color:var(--muted);font-size:.9rem}.last-signal{padding:0 1.5rem 1.5rem;color:var(--muted);font-size:.8rem}.config-page{max-width:800px;margin:0 auto}.config-form{padding:1.5rem;display:flex;flex-direction:column;gap:1rem}.form-actions{padding-top:.5rem}.form-actions button{max-width:220px}#root{max-width:1280px;margin:0 auto;padding:2rem;text-align:center}.logo{height:6em;padding:1.5em;will-change:filter;transition:filter .3s}.logo:hover{filter:drop-shadow(0 0 2em #646cffaa)}.logo.react:hover{filter:drop-shadow(0 0 2em #61dafbaa)}@keyframes logo-spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}@media (prefers-reduced-motion: no-preference){a:nth-of-type(2) .logo{animation:logo-spin infinite 20s linear}}.card{padding:2em}.tabs{display:flex;align-items:center;gap:.5rem;margin:1.5rem 0 .5rem;border-bottom:2px solid #2a2a3a;padding-bottom:.5rem}.tab-btn{background:transparent;border:none;color:#aaa;font-size:.95rem;padding:.4rem 1rem;cursor:pointer;border-radius:6px 6px 0 0;transition:color .2s,background .2s}.tab-btn:hover{color:#fff;background:#1e1e2e}.tab-active{color:#fff!important;background:#2a2a3a!important;border-bottom:2px solid #646cff}.tab-badge{background:#ef4444;color:#fff;border-radius:999px;font-size:.7rem;padding:0 5px;margin-left:4px;vertical-align:middle}.btn-icon{margin-left:auto;background:transparent;border:1px solid #333;color:#aaa;cursor:pointer;padding:.4rem .7rem;border-radius:6px;font-size:1rem}.btn-icon:hover{color:#fff;border-color:#646cff}.perf-bar-wrapper{display:flex;align-items:center;gap:.5rem;min-width:140px}.perf-bar-track{flex:1;height:6px;background:#2a2a3a;border-radius:3px;overflow:hidden}.perf-bar-fill{height:100%;border-radius:3px;transition:width .4s ease}.perf-bar-label{font-size:.78rem;font-weight:600;min-width:40px;text-align:right}.row-error{background:#ef44440f}.error-code{background:#2a1a1a;color:#f87171;padding:2px 6px;border-radius:4px;font-size:.8rem;white-space:nowrap}.signal-id-cell{font-size:.75rem;color:#666;max-width:160px;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.card-error{border:1px solid rgba(239,68,68,.3)}.badge-sent{background:#1d4ed8;color:#fff}.badge-confirmed{background:#15803d;color:#fff}.badge-failed{background:#b91c1c;color:#fff}.badge-validated{background:#7c3aed;color:#fff}.badge-received{background:#374151;color:#fff}.section-header{display:flex;align-items:center;justify-content:space-between;margin-bottom:.75rem}.section-header h2{margin:0}.winrate-cards{display:grid;grid-template-columns:repeat(auto-fit,minmax(160px,1fr));gap:1rem;margin-bottom:1.25rem}.wr-card{background:#1a1025;border:1px solid rgba(168,85,247,.2);border-radius:10px;padding:1rem 1.25rem;text-align:center}.wr-label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.06em;margin-bottom:.35rem}.wr-big{font-size:2rem;font-weight:800;line-height:1.1}.wr-sub{font-size:.7rem;color:#6b7280;margin-top:.3rem}.winrate-chart-box{background:#12091e;border:1px solid rgba(168,85,247,.15);border-radius:10px;padding:1rem 1.25rem;overflow-x:auto}.chart-title{font-size:.75rem;color:#6b7280;margin-bottom:.6rem;text-transform:uppercase;letter-spacing:.05em}.badge-manual{display:inline-block;padding:2px 7px;border-radius:4px;font-size:.72rem;background:#f59e0b26;color:#fbbf24;white-space:nowrap}.badge-auto{display:inline-block;padding:2px 7px;border-radius:4px;font-size:.72rem;background:#8b5cf626;color:#a78bfa;white-space:nowrap}.btn-edit{background:none;border:1px solid rgba(168,85,247,.4);border-radius:5px;cursor:pointer;font-size:1rem;padding:2px 7px;color:#a78bfa;transition:background .15s}.btn-edit:hover{background:#a855f726}.success-banner{background:#10b9811f;border:1px solid rgba(16,185,129,.35);border-radius:7px;color:#34d399;padding:.5rem 1rem;margin-bottom:.75rem;font-size:.9rem}.btn-primary{background:linear-gradient(135deg,#7c3aed,#a855f7);border:none;border-radius:8px;color:#fff;cursor:pointer;font-size:.85rem;font-weight:600;padding:.45rem 1.1rem;transition:opacity .15s}.btn-primary:hover{opacity:.85}.btn-primary:disabled{opacity:.5;cursor:not-allowed}.modal-overlay{position:fixed;top:0;right:0;bottom:0;left:0;background:#000000a6;display:flex;align-items:center;justify-content:center;z-index:1000;padding:1rem}.modal-box{background:#17102b;border:1px solid rgba(168,85,247,.3);border-radius:14px;width:100%;max-width:680px;max-height:90vh;overflow-y:auto;box-shadow:0 24px 60px #0009}.modal-header{display:flex;align-items:center;justify-content:space-between;padding:1rem 1.35rem .75rem;border-bottom:1px solid rgba(168,85,247,.15)}.modal-header h3{margin:0;font-size:1rem;color:#e2e8f0}.modal-close{background:none;border:none;color:#9ca3af;cursor:pointer;font-size:1.1rem;line-height:1;padding:2px 6px;border-radius:4px;transition:color .15s}.modal-close:hover{color:#f87171}.trade-form{padding:1rem 1.35rem 1.25rem}.form-grid{display:grid;grid-template-columns:1fr 1fr;gap:.75rem 1rem}.form-field{display:flex;flex-direction:column;gap:.25rem}.form-field.full{grid-column:1 / -1}.form-field label{font-size:.75rem;color:#9ca3af;text-transform:uppercase;letter-spacing:.04em}.form-field input,.form-field select,.form-field textarea{background:#0f0a1e;border:1px solid rgba(168,85,247,.25);border-radius:6px;color:#e2e8f0;font-size:.9rem;padding:.4rem .65rem;outline:none;transition:border-color .15s;font-family:inherit}.form-field input:focus,.form-field select:focus,.form-field textarea:focus{border-color:#a855f7}.form-field textarea{resize:vertical;min-height:52px}.form-actions{margin-top:1rem;display:flex;justify-content:flex-end}.form-error{background:#3b1c1c;border:1px solid #f87171;border-radius:6px;color:#fca5a5;font-size:.85rem;padding:.55rem .75rem;margin-bottom:.75rem}.filters-bar{display:flex;gap:1rem;margin-bottom:1.5rem;padding:1rem;background:#1f293780;border-radius:8px;align-items:flex-end;flex-wrap:wrap}.filter-group{display:flex;flex-direction:column;gap:.25rem}.filter-group label{font-size:.875rem;color:#9ca3af;font-weight:500}.filter-group input,.filter-group select{padding:.5rem;border-radius:4px;border:1px solid #374151;background:#1f2937;color:#d1d5db;font-size:.875rem;transition:border-color .2s}.filter-group input:focus,.filter-group select:focus{outline:none;border-color:#7c3aed}.risk-pct{color:#f59e0b;font-weight:600}
