:root { --bg:#0f1419; --card:#1a2230; --line:#2a3547; --txt:#e6edf3; --muted:#8b98a9;
        --acc:#3b82f6; --green:#16a34a; --red:#dc2626; }
* { box-sizing: border-box; }
body { margin:0; background:var(--bg); color:var(--txt);
       font:15px/1.5 -apple-system,Segoe UI,Roboto,Helvetica,Arial,sans-serif; }
.wrap { max-width:820px; margin:0 auto; padding:16px; }
header { display:flex; align-items:center; justify-content:space-between; margin:8px 0 16px; }
h1 { font-size:22px; margin:0; }
h2 { font-size:16px; margin:0 0 12px; }
.muted { color:var(--muted); font-weight:400; }
.logout { color:var(--muted); text-decoration:none; font-size:14px; }
.card { background:var(--card); border:1px solid var(--line); border-radius:12px;
        padding:16px; margin-bottom:16px; }
label { display:block; margin-bottom:10px; font-size:13px; color:var(--muted); }
input, select, button { width:100%; padding:10px 12px; border-radius:8px;
        border:1px solid var(--line); background:#0d1320; color:var(--txt); font-size:15px; }
.row { display:flex; gap:12px; } .row label { flex:1; }
.check { display:flex; align-items:center; gap:8px; color:var(--txt); }
.check input { width:auto; }
button { background:var(--acc); border:none; color:#fff; font-weight:600; cursor:pointer; margin-top:6px; }
button:hover { filter:brightness(1.08); }
.err { color:var(--red); } .flash { background:#13310f; border:1px solid #1f5e16;
        padding:10px 12px; border-radius:8px; }

/* agent status */
.status { display:flex; align-items:center; gap:8px; margin-bottom:14px; font-size:14px; }
.dot { width:10px; height:10px; border-radius:50%; background:var(--muted); display:inline-block; }
.dot.on { background:var(--green); box-shadow:0 0 0 3px rgba(22,163,74,.18); }
.dot.off { background:var(--red); }

/* scans / progress panel */
.jobs { display:flex; flex-direction:column; gap:6px; }
.job { display:flex; align-items:center; gap:10px; font-size:13px;
       padding:7px 9px; border:1px solid var(--line); border-radius:8px; }
.jsym { flex:1; min-width:0; overflow:hidden; text-overflow:ellipsis; white-space:nowrap; }
.jmeta { margin-left:auto; white-space:nowrap; }
.jbadge { font-size:11px; padding:2px 9px; border-radius:999px; white-space:nowrap; text-transform:capitalize; }
.jbadge.pending { background:#39320f; color:#e6c24a; }
.jbadge.running { background:#0e2f3a; color:#52c4e6; }
.jbadge.done    { background:#16331f; color:#5fd08a; }
.jbadge.error   { background:#3a1616; color:#ef8a8a; }
.job.running .jbadge { animation:pulse 1.2s ease-in-out infinite; }
@keyframes pulse { 50% { opacity:.45; } }

/* signals header + filter */
.signals-head { display:flex; align-items:center; justify-content:space-between; gap:10px; margin-bottom:10px; }
.signals-head h2 { margin:0; }
#scanFilter { width:auto; max-width:62%; padding:7px 9px; font-size:13px; }

/* signals table */
.table-scroll { overflow-x:auto; -webkit-overflow-scrolling:touch; }
table { width:100%; border-collapse:collapse; font-size:13px; }
th, td { text-align:left; padding:7px 6px; border-bottom:1px solid var(--line); white-space:nowrap; }
td.num, th.num { text-align:right; }
th { cursor:pointer; user-select:none; color:var(--muted); font-weight:600; }
th:hover { color:var(--txt); }
th.sorted { color:var(--txt); }
th[data-dir]:not([data-dir=""])::after { content:attr(data-dir); font-size:10px; margin-left:3px; }
tr.bearish td:first-child { border-left:3px solid var(--red); }
tr.bullish td:first-child { border-left:3px solid var(--green); }

/* ---- mobile: stack each signal into a labeled card ---- */
@media (max-width:560px) {
  .wrap { padding:12px; }
  .row { flex-direction:column; gap:0; }
  .signals-head { flex-direction:column; align-items:stretch; }
  #scanFilter { max-width:100%; width:100%; }
  #signals thead { display:none; }
  #signals, #signals tbody, #signals tr, #signals td { display:block; width:100%; }
  #signals tr { border:1px solid var(--line); border-radius:10px; margin-bottom:10px; padding:8px 12px; }
  #signals tr.bearish { border-left:3px solid var(--red); }
  #signals tr.bullish { border-left:3px solid var(--green); }
  #signals td { display:flex; justify-content:space-between; align-items:center;
                border:none; padding:5px 0; white-space:normal; text-align:right; }
  #signals td::before { content:attr(data-label); color:var(--muted); text-align:left;
                        margin-right:14px; font-weight:600; }
  #signals td:first-child { font-size:15px; padding-bottom:8px; margin-bottom:4px;
                            border-bottom:1px dashed var(--line); }
}
