/* brokers.css — Brokers page styling for the Algo app.
 *
 * Ported 1:1 from the Options app's brokers UI (the self-contained .brk-* rule
 * set that ships inside options-analytics/web/brokers.js → injectStyle()).
 * brokers.js still self-injects the same rules at render time (kept VERBATIM),
 * but those rules reference theme vars with OPTIONS literal fallbacks
 * (--panel-2, --amber, --text-2, --row-hover) that the Algo theme doesn't
 * define. This file:
 *   1. Maps those missing vars onto Algo's palette (scoped to .brk-root +
 *      .brk-modal-bk) so the page inherits Algo's BLUE theme instead of the
 *      baked-in Options literals, and
 *   2. Re-declares the brokers-page .brk-* rules using Algo's CSS vars
 *      (var(--accent)/--panel/--panel2/--border/--text/--muted/--red/--green)
 *      so the layout is correct even without the JS injection.
 *
 * Linked from index.html <head> as <link rel="stylesheet" href="/brokers.css">.
 * A separate file keeps the ~675 KB index.html manageable.
 */

/* ── Theme-var bridge: Algo defines --accent/--panel/--panel2/--border/--text/
 *    --muted/--red/--green/--bg/--green-soft/--accent-soft but NOT --panel-2/
 *    --amber/--text-2/--row-hover, which the JS-injected rules reference (with
 *    Options literal fallbacks). Map the missing vars onto Algo's palette so the
 *    page inherits Algo's BLUE theme. brokers.js's injectStyle() also scopes a
 *    periwinkle "--accent:#8fb8ff" to .brk-root; the :root prefix below raises
 *    specificity so Algo's own --accent wins regardless of <style> source order. */
:root .brk-root,
:root .brk-modal-bk {
  --panel-2: var(--panel2);         /* options used --panel-2; algo uses --panel2 */
  --text-2: var(--muted);
  --amber: #d4a857;                 /* algo has no amber — keep the options amber literal */
  --row-hover: var(--accent-soft);
}
/* Neutralise brokers.js's periwinkle accent override → use Algo's theme accent. */
:root[data-theme="blue"]  .brk-root, :root[data-theme="blue"]  .brk-modal-bk { --accent: #3da3ff; }
:root[data-theme="dark"]  .brk-root, :root[data-theme="dark"]  .brk-modal-bk { --accent: #7aa9f0; }
:root[data-theme="light"] .brk-root, :root[data-theme="light"] .brk-modal-bk { --accent: #2962ff; }

.brk-root {
  padding: 14px 18px;
  background: var(--bg);
  --brk-sh: 0 1px 2px rgba(0, 0, 0, .18);
  --brk-sh-lg: 0 10px 28px rgba(0, 0, 0, .30);
}

.brk-split { display: grid; grid-template-columns: 1.9fr 1fr; gap: 20px; align-items: start; }
@media (max-width: 1000px) { .brk-split { grid-template-columns: 1fr; } }

.brk-card { background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 16px 18px; box-shadow: var(--brk-sh); }

/* segmented tabs */
.brk-tabs { display: inline-flex; gap: 4px; margin-bottom: 16px; background: var(--panel2); border: 1px solid var(--border); border-radius: 11px; padding: 4px; }
.brk-tab { padding: 8px 18px; cursor: pointer; font-weight: 600; font-size: 13px; color: var(--muted); border-radius: 8px; transition: color .14s, background .14s, box-shadow .14s; }
.brk-tab:hover { color: var(--text); }
.brk-tab.active { color: var(--text); background: var(--panel); box-shadow: var(--brk-sh); }

/* headers */
.brk-h { font-size: 17px; font-weight: 700; color: var(--text); margin: 0; letter-spacing: -.01em; display: flex; align-items: center; gap: 8px; }
.brk-h .brk-count { font-size: 12px; font-weight: 700; color: var(--accent); background: var(--accent-soft); border-radius: 999px; padding: 2px 9px; }
.brk-sub { font-size: 12.5px; color: var(--muted); margin: 4px 0 14px; }

/* counts — inline, on the same row as the tabs */
.brk-tabrow { display: flex; align-items: center; justify-content: space-between; gap: 14px; margin-bottom: 16px; flex-wrap: wrap; }
.brk-tabrow .brk-tabs { margin-bottom: 0; }
.brk-statbar:empty { display: none; }
.brk-statinline { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.brk-statchip { display: inline-flex; align-items: center; gap: 6px; background: var(--panel); border: 1px solid var(--border); border-radius: 10px; padding: 6px 12px; font-size: 12px; color: var(--muted); white-space: nowrap; box-shadow: var(--brk-sh); }
.brk-statchip b { font-size: 15px; font-weight: 800; color: var(--text); letter-spacing: -.02em; }
.brk-statchip b.acc { color: var(--accent); }
.brk-statchip b.on { color: var(--green); }

/* table */
.brk-tbl { width: 100%; border-collapse: separate; border-spacing: 0; font-size: 13px; }
.brk-tbl th { text-align: left; color: var(--muted); font-weight: 600; font-size: 10.5px; text-transform: uppercase; letter-spacing: .06em; padding: 10px 12px; border-bottom: 1px solid var(--border); }
.brk-tbl td { padding: 11px 12px; border-bottom: 1px solid var(--border); color: var(--text); vertical-align: middle; }
.brk-tbl tbody tr { transition: background .12s; }
.brk-tbl tbody tr:hover td { background: var(--accent-soft); }
.brk-tbl tbody tr:last-child td { border-bottom: none; }

/* enable toggle button — stable width so "Enable" / "✓ Enabled" don't shift the column */
.brk-act1 { min-width: 92px; }
.brk-en { min-width: 96px; }
.brk-en:not(.go) { background: transparent; border: 1px solid var(--border); }
.brk-btn.brk-en[disabled] { opacity: .75; cursor: not-allowed; }
.brk-btn.brk-en[disabled]:not(.go) { opacity: 1; color: var(--muted); border: 1px solid var(--border); background: transparent; }

/* themed checkbox (auto-login toggle in setup form) */
.brk-toggle input[type=checkbox] { appearance: none; -webkit-appearance: none; width: 18px; height: 18px; border: 1.5px solid var(--border); border-radius: 5px; background: var(--panel2); cursor: pointer; position: relative; margin: 0; flex: 0 0 auto; vertical-align: middle; transition: border-color .14s, background .14s; }
.brk-toggle input[type=checkbox]:hover { border-color: var(--accent); }
.brk-toggle input[type=checkbox]:checked { background: var(--accent); border-color: var(--accent); }
.brk-toggle input[type=checkbox]:checked::after { content: ""; position: absolute; left: 5px; top: 1.5px; width: 4px; height: 9px; border: solid var(--bg); border-width: 0 2px 2px 0; transform: rotate(45deg); }

.brk-bk-cell { display: flex; align-items: center; gap: 10px; font-weight: 600; }
.brk-logo-chip { width: 30px; height: 30px; border-radius: 8px; background: #fff; display: flex; align-items: center; justify-content: center; flex: 0 0 auto; box-shadow: var(--brk-sh); }
.brk-logo-chip img { width: 20px; height: 20px; object-fit: contain; }
.brk-tag { display: inline-block; padding: 3px 10px; border-radius: 999px; font-size: 11px; font-weight: 600; background: var(--accent-soft); color: var(--accent); }

/* status pill */
.brk-pill { display: inline-flex; align-items: center; gap: 6px; font-size: 11.5px; font-weight: 600; padding: 4px 10px; border-radius: 999px; }
.brk-dot { width: 7px; height: 7px; border-radius: 50%; display: inline-block; }
.brk-pill.on { background: var(--green-soft); color: var(--green); }
.brk-pill.on .brk-dot { background: var(--green); box-shadow: 0 0 0 3px var(--green-soft); }
.brk-pill.off { background: var(--panel2); color: var(--muted); }
.brk-pill.off .brk-dot { background: var(--amber); }

/* buttons */
.brk-btn { display: inline-flex; align-items: center; justify-content: center; gap: 5px; min-height: 32px; box-sizing: border-box; padding: 6px 14px; border-radius: 8px; border: 1px solid var(--border); background: var(--panel2); color: var(--text); cursor: pointer; font-size: 12px; font-weight: 600; white-space: nowrap; line-height: 1; transition: border-color .14s, background .14s, transform .1s, filter .14s, box-shadow .14s; }
.brk-btn:hover { border-color: var(--accent); transform: translateY(-1px); }
.brk-btn.go { border: 1px solid var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); color: var(--accent); font-weight: 600; }
.brk-btn.go:hover { background: color-mix(in srgb, var(--accent) 16%, transparent); border-color: var(--accent); transform: translateY(-1px); }
.brk-btn.warn { border: 1px solid var(--amber); background: color-mix(in srgb, var(--amber) 8%, transparent); color: var(--amber); }
.brk-btn.warn:hover { background: color-mix(in srgb, var(--amber) 16%, transparent); border-color: var(--amber); transform: translateY(-1px); }
.brk-btn.danger { border: 1px solid var(--red); background: color-mix(in srgb, var(--red) 8%, transparent); color: var(--red); padding: 6px 11px; }
.brk-btn.danger:hover { background: color-mix(in srgb, var(--red) 16%, transparent); border-color: var(--red); transform: translateY(-1px); }
.brk-btn.danger svg { display: block; }
.brk-btn[disabled] { opacity: .5; cursor: not-allowed; transform: none; box-shadow: none; }

/* Buy / upgrade CTA panel (green — money/go semantic; never primary-blue). */
.brk-buy-card { margin-top: 16px; }
.brk-buy-grid { display: grid; grid-template-columns: repeat(4, minmax(0, 1fr)); gap: 12px; margin-top: 14px; }
@media (max-width: 980px) { .brk-buy-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
@media (max-width: 560px) { .brk-buy-grid { grid-template-columns: 1fr; } }
.brk-buy { display: flex; align-items: center; gap: 11px; text-decoration: none; border: 1px solid color-mix(in srgb, var(--green) 42%, var(--border)); border-radius: 12px; padding: 13px 14px; background: linear-gradient(180deg, color-mix(in srgb, var(--green) 13%, transparent), color-mix(in srgb, var(--green) 4%, transparent)); transition: border-color .15s, transform .12s, box-shadow .15s, background .15s; }
.brk-buy:hover { border-color: var(--green); transform: translateY(-2px); box-shadow: 0 6px 18px color-mix(in srgb, var(--green) 22%, transparent); background: linear-gradient(180deg, color-mix(in srgb, var(--green) 20%, transparent), color-mix(in srgb, var(--green) 7%, transparent)); }
.brk-buy-ic { font-size: 20px; line-height: 1; flex: 0 0 auto; }
.brk-buy-tx { display: flex; flex-direction: column; gap: 2px; min-width: 0; }
.brk-buy-tx b { font-size: 13px; font-weight: 700; color: var(--text); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
.brk-buy-tx small { font-size: 11px; color: var(--muted); line-height: 1.25; }
.brk-buy-arrow { margin-left: auto; color: var(--green); font-weight: 700; font-size: 15px; flex: 0 0 auto; transition: transform .15s; }
.brk-buy:hover .brk-buy-arrow { transform: translateX(3px); }

.brk-actions { display: flex; gap: 7px; align-items: center; }
.brk-assign { color: var(--accent); cursor: pointer; font-size: 12px; font-weight: 600; }
.brk-assign:hover { text-decoration: underline; }

/* notes */
.brk-notes { background: linear-gradient(180deg, var(--accent-soft), transparent); border: 1px solid var(--border); border-radius: 14px; padding: 14px 18px; margin-top: 16px; }
.brk-notes h5 { margin: 0 0 8px; font-size: 13px; color: var(--text); display: flex; align-items: center; gap: 7px; }
.brk-notes h5::before { content: ""; width: 6px; height: 6px; border-radius: 50%; background: var(--accent); box-shadow: 0 0 0 3px var(--accent-soft); }
.brk-notes ul { margin: 0 0 0 18px; font-size: 12px; color: var(--muted); line-height: 1.8; }

/* available grid */
.brk-avail-grp { font-size: 12px; font-weight: 700; color: var(--muted); margin: 10px 0 8px; }
.brk-grid { display: grid; grid-template-columns: repeat(3, minmax(0, 1fr)); gap: 12px; }
.brk-bcard { position: relative; border: 1px solid var(--border); border-radius: 13px; padding: 16px 8px 14px; display: flex; flex-direction: column; align-items: center; gap: 10px; cursor: pointer; background: linear-gradient(180deg, rgba(255, 255, 255, .025), rgba(255, 255, 255, 0)); transition: border-color .16s, transform .16s, box-shadow .16s; }
.brk-bcard:hover { border-color: var(--accent); transform: translateY(-3px); box-shadow: var(--brk-sh-lg); }
.brk-bcard .logo-wrap { width: 48px; height: 48px; border-radius: 12px; background: #fff; display: flex; align-items: center; justify-content: center; box-shadow: var(--brk-sh); }
.brk-bcard img { width: 34px; height: 34px; object-fit: contain; }
.brk-bcard .ini { width: 48px; height: 48px; border-radius: 12px; background: var(--accent); color: var(--bg); display: flex; align-items: center; justify-content: center; font-weight: 800; font-size: 18px; }
.brk-bcard .nm { font-size: 12.5px; font-weight: 600; color: var(--text); text-align: center; line-height: 1.25; }
.brk-bcard .st { font-size: 10px; color: var(--muted); }
.brk-open { text-align: center; margin-top: 18px; }
.brk-open-h { font-size: 13px; font-weight: 700; color: var(--text); }
.brk-open-sub { font-size: 11.5px; color: var(--muted); margin: 3px 0 12px; }
.brk-open-links { display: flex; flex-wrap: wrap; gap: 8px; justify-content: center; }
.brk-open-link { display: inline-flex; align-items: center; gap: 7px; border: 1px solid var(--accent); background: color-mix(in srgb, var(--accent) 8%, transparent); color: var(--accent); font-weight: 600; font-size: 12px; padding: 7px 13px; border-radius: 9px; text-decoration: none; transition: background .14s, transform .1s; }
.brk-open-link:hover { background: color-mix(in srgb, var(--accent) 16%, transparent); transform: translateY(-1px); }
.brk-open-link img { width: 18px; height: 18px; object-fit: contain; border-radius: 4px; background: #fff; }

/* setup view — single column by default; ".two" adds the instructions panel */
.brk-setup { display: grid; grid-template-columns: 1fr; gap: 18px; align-items: start; }
.brk-setup.two { grid-template-columns: 380px 1fr; }
@media (max-width: 900px) { .brk-setup.two { grid-template-columns: 1fr; } }
#brk-help:empty { display: none; }
.brk-back { display: inline-flex; align-items: center; gap: 6px; margin-bottom: 14px; color: var(--accent); cursor: pointer; font-size: 13px; font-weight: 600; }
.brk-back:hover { text-decoration: underline; }
.brk-fg { display: flex; flex-direction: column; gap: 5px; margin-bottom: 13px; }
.brk-fg label { font-size: 12px; color: var(--muted); }
.brk-fg label .req { color: var(--red); }
.brk-fg input, .brk-sel { background: transparent; border: 1px solid var(--border); border-radius: 8px; color: var(--text); padding: 9px 11px; font-size: 13px; width: 100%; box-sizing: border-box; transition: border-color .14s, box-shadow .14s; }
.brk-fg input::placeholder { color: var(--muted); opacity: .7; }
.brk-fg input:focus, .brk-sel:focus { outline: none; border-color: var(--accent); box-shadow: 0 0 0 3px color-mix(in srgb, var(--accent) 22%, transparent); }
.brk-sel { background: var(--panel); }
.brk-sel option { background: var(--panel); color: var(--text); }
.brk-sel option:checked { background: var(--accent); color: #fff; }
.brk-purpose { display: flex; gap: 8px; }
.brk-purpose label { flex: 1; border: 1px solid var(--border); border-radius: 9px; padding: 9px 11px; cursor: pointer; display: flex; flex-direction: column; transition: border-color .14s, background .14s; }
.brk-purpose label.sel { border-color: var(--accent); background: var(--accent-soft); }
.brk-purpose .pl { font-size: 13px; font-weight: 600; color: var(--text); }
.brk-purpose .pd { font-size: 11px; color: var(--muted); }
.brk-purpose input { display: none; }
.brk-toggle { display: flex; align-items: center; gap: 8px; font-size: 13px; color: var(--text); margin-bottom: 13px; }
#brk-save { width: 100%; padding: 10px; font-size: 13px; }
.brk-redir { background: color-mix(in srgb, var(--accent) 7%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 30%, transparent); border-radius: 9px; padding: 10px 12px; font-size: 12px; margin-bottom: 12px; }
.brk-redir code { color: var(--accent); word-break: break-all; }
.brk-redir a { color: var(--accent); }
.brk-steps .brk-step { border: 1px solid var(--border); border-radius: 9px; margin-bottom: 8px; overflow: hidden; }
.brk-steps .brk-step > summary { padding: 10px 12px; cursor: pointer; font-size: 13px; font-weight: 600; color: var(--text); list-style: none; background: transparent; transition: background .14s; }
.brk-steps .brk-step > summary:hover { background: color-mix(in srgb, var(--accent) 8%, transparent); }
.brk-steps .brk-step > summary::-webkit-details-marker { display: none; }
.brk-steps .brk-step[open] > summary { border-bottom: 1px solid var(--border); }
.brk-steps .brk-step-body { padding: 10px 12px; font-size: 12.5px; color: var(--text); line-height: 1.5; }
.brk-steps .brk-step ul { margin: 6px 0 0 18px; }
.brk-cfg-img { margin-top: 8px; }
.brk-cfg-img img { max-width: 100%; border: 1px solid var(--border); border-radius: 6px; }
.brk-empty { padding: 30px; text-align: center; color: var(--muted); }
.brk-note { font-size: 12px; color: var(--muted); }

/* modal / popover */
.brk-modal-bk { position: fixed; inset: 0; background: rgba(4, 10, 20, 0.62); backdrop-filter: blur(3px); z-index: 9998; display: flex; align-items: center; justify-content: center; animation: brkFade .15s ease; }
@keyframes brkFade { from { opacity: 0; } to { opacity: 1; } }
.brk-modal { background: var(--panel); border: 1px solid var(--border); border-radius: 14px; padding: 20px; width: 360px; max-width: calc(100vw - 32px); box-shadow: 0 18px 50px rgba(0, 0, 0, .5); animation: brkPop .16s ease; }
@keyframes brkPop { from { opacity: 0; transform: translateY(8px) scale(.98); } to { opacity: 1; transform: none; } }
.brk-modal h3 { margin: 0 0 12px; font-size: 15px; color: var(--text); display: flex; align-items: center; gap: 8px; }
.brk-setup-modal { width: min(460px, calc(100vw - 40px)); padding: 0; }
.brk-setup-modal.wide { width: min(960px, calc(100vw - 40px)); }
.brk-setup-head { display: flex; align-items: center; justify-content: space-between; padding: 15px 20px; border-bottom: 1px solid var(--border); cursor: move; user-select: none; }
.brk-api-h { margin: 0 0 14px; font-size: 15px; font-weight: 700; color: var(--text); }
.brk-apirow { margin-bottom: 14px; }
.brk-apirow > label { display: block; font-size: 10.5px; font-weight: 700; color: var(--muted); text-transform: uppercase; letter-spacing: .05em; margin-bottom: 6px; }
.brk-apirow a { color: var(--accent); font-weight: 600; word-break: break-all; text-decoration: none; }
.brk-apirow a:hover { text-decoration: underline; }
.brk-copyfield { display: flex; align-items: center; gap: 8px; background: color-mix(in srgb, var(--accent) 7%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 28%, transparent); border-radius: 8px; padding: 8px 10px; }
.brk-copyfield code { flex: 1; color: var(--text); font-size: 12px; word-break: break-all; font-family: monospace; }
.brk-copybtn { background: transparent; border: none; color: var(--accent); cursor: pointer; font-size: 14px; line-height: 1; padding: 3px 5px; border-radius: 6px; flex: 0 0 auto; }
.brk-copybtn:hover { background: color-mix(in srgb, var(--accent) 16%, transparent); }
.brk-ips { display: flex; flex-wrap: wrap; gap: 8px; }
.brk-ipchip { display: inline-flex; align-items: center; gap: 6px; background: color-mix(in srgb, var(--accent) 6%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent); border-radius: 8px; padding: 5px 8px; font-size: 12px; }
.brk-ipchip code { font-family: monospace; font-weight: 700; color: var(--text); }
.brk-ipchip-tag { background: color-mix(in srgb, var(--amber) 22%, transparent); color: var(--amber); font-size: 9.5px; font-weight: 700; padding: 1px 6px; border-radius: 999px; text-transform: uppercase; letter-spacing: .03em; }
.brk-setup-head h3 { margin: 0; font-size: 16px; font-weight: 700; color: var(--text); display: flex; align-items: center; gap: 10px; }
.brk-setup-logo { display: inline-flex; align-items: center; justify-content: center; width: 28px; height: 28px; border-radius: 8px; background: #fff; box-shadow: 0 1px 2px rgba(0, 0, 0, .2); }
.brk-setup-logo:empty { display: none; }
.brk-setup-logo img { width: 19px; height: 19px; object-fit: contain; }
.brk-ip-buy { font-size: 12px; color: var(--muted); line-height: 1.5; background: color-mix(in srgb, var(--accent) 6%, transparent); border: 1px solid color-mix(in srgb, var(--accent) 22%, transparent); border-radius: 9px; padding: 10px 12px; }
.brk-ip-buy a { color: var(--accent); font-weight: 700; text-decoration: none; white-space: nowrap; }
.brk-ip-buy a:hover { text-decoration: underline; }
.brk-x { background: transparent; border: none; color: var(--muted); font-size: 24px; line-height: 1; cursor: pointer; padding: 2px 8px; border-radius: 8px; }
.brk-x:hover { color: var(--text); background: var(--panel2); }
.brk-setup-body { padding: 18px 20px; max-height: calc(100vh - 170px); overflow: auto; }
.brk-setup-body .brk-card { background: transparent; border: none; box-shadow: none; padding: 0; }
.brk-modal .brk-msg { font-size: 13px; color: var(--text); line-height: 1.55; margin-bottom: 18px; }
.brk-modal .brk-msg b { color: var(--text); }

/* broker-limit upsell cards */
.brk-up-wrap { display: flex; flex-direction: column; gap: 10px; }
.brk-up-card { display: block; text-decoration: none; border: 1px solid var(--border); border-radius: 10px; padding: 12px 14px; background: var(--panel2); transition: border-color .12s, transform .12s; }
.brk-up-card:hover { border-color: var(--accent); transform: translateY(-1px); }
.brk-up-t { font-size: 13.5px; font-weight: 700; color: var(--text); }
.brk-up-d { font-size: 12px; color: var(--text); line-height: 1.5; margin: 3px 0 6px; }
.brk-up-cta { font-size: 12px; font-weight: 600; color: var(--accent); }

/* themed toast */
.brk-toast-host { position: fixed; top: 16px; right: 16px; z-index: 10000; display: flex; flex-direction: column; gap: 8px; pointer-events: none; }
.brk-toast { display: flex; align-items: center; gap: 9px; background: var(--panel); border: 1px solid var(--border); border-left: 3px solid var(--accent); border-radius: 10px; padding: 11px 15px; font-size: 13px; font-weight: 500; color: var(--text); box-shadow: 0 12px 30px rgba(0, 0, 0, .4); max-width: 340px; opacity: 0; transform: translateX(16px); transition: opacity .22s ease, transform .22s ease; }
.brk-toast.show { opacity: 1; transform: none; }
.brk-toast.ok { border-left-color: var(--green); }
.brk-toast.err { border-left-color: var(--red); }
.brk-toast .ico { font-size: 14px; line-height: 1; }
