:root{
  --bg:#0d1117; --panel:#161b22; --border:#30363d; --text:#e6edf3;
  --muted:#8b949e; --green:#3fb950; --red:#f85149; --blue:#388bfd;
  --amber:#d29922;
}
*{box-sizing:border-box}
body{margin:0;font-family:-apple-system,Segoe UI,Roboto,sans-serif;background:var(--bg);color:var(--text)}
.topbar{display:flex;justify-content:space-between;align-items:center;padding:14px 22px;border-bottom:1px solid var(--border);background:var(--panel)}
.brand{font-weight:700;font-size:18px;display:flex;align-items:center}
.brand-logo{height:40px;width:auto;display:block}
.badge{padding:5px 12px;border-radius:20px;font-size:13px;font-weight:600}
.badge-muted{background:#21262d;color:var(--muted)}
.badge-ok{background:rgba(63,185,80,.15);color:var(--green)}
.badge-bad{background:rgba(248,81,73,.15);color:var(--red)}

.indices{display:grid;grid-template-columns:repeat(3,1fr);gap:16px;padding:22px}
.index-card{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:18px}
.idx-name{color:var(--muted);font-size:13px;letter-spacing:.5px;font-weight:600}
.idx-last{font-size:30px;font-weight:700;margin:8px 0}
.idx-change{font-size:15px;font-weight:600}
.up{color:var(--green)} .down{color:var(--red)}

.panel{background:var(--panel);border:1px solid var(--border);border-radius:12px;margin:0 22px 22px;padding:18px}
.panel-head{display:flex;justify-content:space-between;align-items:center;margin-bottom:14px}
.panel-head h3{margin:0;font-size:16px}
.broker-actions,.strategy-actions{display:flex;gap:10px}

.btn{cursor:pointer;border:1px solid var(--border);background:#21262d;color:var(--text);padding:9px 16px;border-radius:8px;font-size:14px;font-weight:600}
.btn:hover{filter:brightness(1.15)}
.btn:disabled{opacity:.45;cursor:not-allowed}
.btn-sm{padding:6px 12px;font-size:13px}
.btn-primary{background:var(--blue);border-color:var(--blue);color:#fff}
.btn-danger{background:var(--red);border-color:var(--red);color:#fff;animation:pulse 1.6s infinite}
.btn-warning{background:var(--amber);border-color:var(--amber);color:#1a1a1a}
.btn-start{background:var(--green);border-color:var(--green);color:#04250f}
.btn-stop{background:var(--red);border-color:var(--red);color:#fff}
@keyframes pulse{0%,100%{box-shadow:0 0 0 0 rgba(248,81,73,.5)}50%{box-shadow:0 0 0 8px rgba(248,81,73,0)}}

.broker-info{color:var(--muted);font-size:14px}

.grid{display:grid;grid-template-columns:repeat(4,1fr);gap:12px;margin-bottom:14px}
.stat{background:#0d1117;border:1px solid var(--border);border-radius:8px;padding:12px}
.stat span{display:block;color:var(--muted);font-size:12px;margin-bottom:5px}
.stat b{font-size:17px}

.vars{margin:10px 0;background:#0d1117;border:1px solid var(--border);border-radius:8px;padding:12px}
.vars summary{cursor:pointer;font-weight:600;color:var(--blue)}
.vars-grid{display:grid;grid-template-columns:repeat(3,1fr);gap:12px;margin:14px 0}
.vars-grid label{display:block;font-size:12px;color:var(--muted);margin-bottom:4px}
.vars-grid input,.vars-grid select{width:100%;padding:7px;background:#161b22;border:1px solid var(--border);border-radius:6px;color:var(--text)}
.saved-note{color:var(--green);font-size:13px;margin-left:10px}

.log{margin:14px 0;font-size:13px;color:var(--muted);font-family:monospace}
.trades{width:100%;border-collapse:collapse;font-size:13px}
.trades th,.trades td{text-align:left;padding:8px;border-bottom:1px solid var(--border)}
.trades th{color:var(--muted);font-weight:600}

.modal-overlay{position:fixed;inset:0;background:rgba(0,0,0,.65);display:flex;align-items:center;justify-content:center;z-index:50}
.modal{background:var(--panel);border:1px solid var(--border);border-radius:12px;padding:24px;width:420px;max-width:92vw}
.modal h3{margin:0 0 16px}
.modal label{display:block;font-size:13px;color:var(--muted);margin:12px 0 5px}
.modal input{width:100%;padding:10px;background:#0d1117;border:1px solid var(--border);border-radius:8px;color:var(--text)}
.broker-select{display:flex;gap:10px;margin-bottom:6px}
.broker-chip{padding:8px 16px;border-radius:8px;border:1px solid var(--border);background:#0d1117;color:var(--text);cursor:pointer}
.broker-chip.selected{border-color:var(--blue);background:rgba(56,139,253,.15);color:var(--blue)}
.hint{font-size:12px;color:var(--muted);margin-top:14px}
.hint code{background:#0d1117;padding:2px 6px;border-radius:4px}
.modal-actions{display:flex;justify-content:flex-end;gap:10px;margin-top:18px}
.modal-err{color:var(--red);font-size:13px;margin-top:10px}

.topbar-right{display:flex;align-items:center;gap:14px}
.topbar-user{color:var(--muted);font-size:13px}

.login-wrap{min-height:100vh;display:flex;align-items:center;justify-content:center}
.login-card{background:var(--panel);border:1px solid var(--border);border-radius:14px;padding:34px;width:360px;max-width:92vw}
.login-brand{font-size:24px;font-weight:700;text-align:center}
.login-sub{text-align:center;color:var(--muted);margin:6px 0 22px}
.login-card label{display:block;font-size:13px;color:var(--muted);margin:12px 0 5px}
.login-card input{width:100%;padding:11px;background:#0d1117;border:1px solid var(--border);border-radius:8px;color:var(--text)}
.login-btn{width:100%;margin-top:20px;padding:12px}
.login-err{color:var(--red);font-size:13px;margin-top:14px;text-align:center}
