/* Az Signal Hub v1.2 — Bloomberg-inspired dark terminal */
*, *::before, *::after { box-sizing: border-box; margin: 0; padding: 0; }

/* ── Custom scrollbar ───────────────────────────────────────────────────────── */
::-webkit-scrollbar { width: 6px; height: 6px; }
::-webkit-scrollbar-track { background: var(--bg); }
::-webkit-scrollbar-thumb { background: var(--border2); border-radius: 3px; }
::-webkit-scrollbar-thumb:hover { background: var(--muted); }

/* ── Variables ──────────────────────────────────────────────────────────────── */
:root,
[data-theme="dark"] {

  /* Base backgrounds */
  --bg:          #0a0e17;
  --bg2:         #0a0e17;
  --surface:     #0f1520;
  --surface2:    #141b2d;
  --surface3:    #1a2238;
  --overlay:     #1f2940;

  /* Borders */
  --border:      #1e2d47;
  --border2:     #253552;
  --border3:     #2d4068;

  /* Text */
  --text:        #e8ecf4;
  --text2:       #a8b4cc;
  --text3:       #6b7a99;
  --text4:       #3d4d6a;
  --muted:       #6b7a99;
  --label:       #6b7a99;

  /* Brand accent — professional blue */
  --accent:      #2563eb;
  --accent2:     #1d4ed8;
  --accent-dim:  rgba(37,99,235,0.12);
  --accent-glow: rgba(37,99,235,0.08);

  /* Signal colours — muted professional */
  --long:        #16a34a;
  --long-bright: #22c55e;
  --long-bg:     rgba(22,163,74,0.08);
  --long-border: rgba(22,163,74,0.25);
  --long-glow:   rgba(22,163,74,0.12);

  --short:       #dc2626;
  --short-bright:#ef4444;
  --short-bg:    rgba(220,38,38,0.08);
  --short-border:rgba(220,38,38,0.25);
  --short-glow:  rgba(220,38,38,0.12);

  --neutral:     #d97706;
  --neutral-bg:  rgba(217,119,6,0.08);
  --neutral-border: rgba(217,119,6,0.25);

  --conflict:    #ea580c;
  --conflict-bg: rgba(234,88,12,0.08);

  /* Status */
  --safe:        #16a34a;
  --safe-bg:     rgba(22,163,74,0.08);
  --safe-border: #16a34a;
  --safe-text:   #22c55e;
  --danger:      #dc2626;
  --danger-bg:   rgba(220,38,38,0.08);
  --danger-border: #dc2626;
  --danger-text: #ef4444;
  --warning:     #d97706;
  --warning-bg:  rgba(217,119,6,0.08);
  --blocked:     #374151;
  --blocked-bg:  rgba(55,65,81,0.3);

  /* Status semantic */
  --success:     #15803d;
  --success-bg:  rgba(21,128,61,0.10);
  --info:        #1d4ed8;
  --info-bg:     rgba(29,78,216,0.10);

  /* Rank */
  --gold:        #d4af37;
  --silver:      #9ca3af;
  --bronze:      #b87333;

  /* Typography */
  --font-sans:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-main:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:   'JetBrains Mono', 'Fira Code', 'Cascadia Code', 'Consolas', monospace;

  /* Border radius */
  --radius-sm:   4px;
  --radius:      6px;
  --radius-lg:   10px;
  --radius-xl:   14px;

  /* Shadows */
  --shadow-sm:   0 1px 3px rgba(0,0,0,0.4);
  --shadow:      0 2px 8px rgba(0,0,0,0.5);
  --shadow-lg:   0 4px 20px rgba(0,0,0,0.6);

  /* Nav */
  --nav-bg:      #080c14;
  --nav-border:  #1a2440;
  --nav-height:  44px;

  /* Table */
  --table-head:  #0d1525;
  --table-row-hover: rgba(37,99,235,0.05);
  --table-border: #1a2440;

  /* Legacy execution/display/research colours */
  --exec-bg:     rgba(217,119,6,0.08);
  --exec-border: #d97706;
  --exec-text:   #fbbf24;
  --exec-badge:  #d97706;
  --display-bg:       rgba(37,99,235,0.08);
  --display-border:   #2563eb;
  --display-text:     #93c5fd;
  --display-badge:    #2563eb;
  --research-bg:      rgba(29,78,216,0.08);
  --research-border:  #1d4ed8;
  --research-text:    #60a5fa;
  --research-badge:   #1d4ed8;
  --paper-bg:         rgba(202,138,4,0.08);
  --paper-border:     #ca8a04;
  --paper-text:       #fde047;
}

/* ── Light mode ─────────────────────────────────────────────────────────────── */
[data-theme="light"] {
  --bg:          #f0f2f7;
  --bg2:         #f0f2f7;
  --surface:     #ffffff;
  --surface2:    #f8f9fc;
  --surface3:    #eef0f6;
  --overlay:     #ffffff;

  --border:      #dde1eb;
  --border2:     #c8cdd9;
  --border3:     #a0a9bf;

  --text:        #0f172a;
  --text2:       #334155;
  --text3:       #64748b;
  --text4:       #94a3b8;
  --muted:       #64748b;
  --label:       #64748b;

  --accent:      #1d4ed8;
  --accent2:     #1e40af;
  --accent-dim:  rgba(29,78,216,0.08);
  --accent-glow: rgba(29,78,216,0.05);

  --long:        #15803d;
  --long-bright: #16a34a;
  --long-bg:     rgba(21,128,61,0.06);
  --long-border: rgba(21,128,61,0.2);
  --long-glow:   rgba(21,128,61,0.08);

  --short:       #b91c1c;
  --short-bright:#dc2626;
  --short-bg:    rgba(185,28,28,0.06);
  --short-border:rgba(185,28,28,0.2);
  --short-glow:  rgba(185,28,28,0.08);

  --neutral:     #92400e;
  --neutral-bg:  rgba(146,64,14,0.06);
  --neutral-border: rgba(146,64,14,0.2);

  --conflict:    #c2410c;
  --conflict-bg: rgba(194,65,12,0.06);

  --safe:        #15803d;
  --safe-bg:     rgba(21,128,61,0.08);
  --safe-border: #15803d;
  --safe-text:   #16a34a;
  --danger:      #b91c1c;
  --danger-bg:   rgba(185,28,28,0.08);
  --danger-border:#b91c1c;
  --danger-text: #dc2626;
  --warning:     #92400e;
  --warning-bg:  rgba(146,64,14,0.08);
  --blocked:     #6b7280;
  --blocked-bg:  rgba(107,114,128,0.15);

  --success:     #166534;
  --success-bg:  rgba(22,101,52,0.08);
  --info:        #1e40af;
  --info-bg:     rgba(30,64,175,0.08);

  --gold:        #b45309;
  --silver:      #6b7280;
  --bronze:      #92400e;

  --font-sans:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-main:   'Inter', -apple-system, BlinkMacSystemFont, 'Segoe UI', sans-serif;
  --font-mono:   'JetBrains Mono', 'Fira Code', 'Cascadia Code', 'Consolas', monospace;

  --radius-sm:   4px;
  --radius:      6px;
  --radius-lg:   10px;
  --radius-xl:   14px;

  --shadow-sm:   0 1px 3px rgba(0,0,0,0.08);
  --shadow:      0 2px 8px rgba(0,0,0,0.10);
  --shadow-lg:   0 4px 20px rgba(0,0,0,0.12);

  --nav-bg:      #0f172a;
  --nav-border:  #1e293b;
  --nav-height:  44px;

  --table-head:  #f1f3f9;
  --table-row-hover: rgba(29,78,216,0.03);
  --table-border: #e2e6f0;

  --exec-bg:     rgba(146,64,14,0.08);
  --exec-border: #92400e;
  --exec-text:   #b45309;
  --exec-badge:  #92400e;
  --display-bg:       rgba(29,78,216,0.06);
  --display-border:   #1d4ed8;
  --display-text:     #1d4ed8;
  --display-badge:    #1d4ed8;
  --research-bg:      rgba(30,64,175,0.06);
  --research-border:  #1e40af;
  --research-text:    #1e40af;
  --research-badge:   #1e40af;
  --paper-bg:         rgba(180,83,9,0.08);
  --paper-border:     #b45309;
  --paper-text:       #92400e;
}

/* ── Typography scale ───────────────────────────────────────────────────────── */
.text-xs   { font-size: 11px; line-height: 1.4; }
.text-sm   { font-size: 12px; line-height: 1.5; }
.text-base { font-size: 13px; line-height: 1.6; }
.text-md   { font-size: 14px; line-height: 1.6; }
.text-lg   { font-size: 16px; line-height: 1.5; }
.text-xl   { font-size: 18px; line-height: 1.4; }
.text-2xl  { font-size: 22px; line-height: 1.3; }
.text-3xl  { font-size: 28px; line-height: 1.2; }
.font-normal { font-weight: 400; }
.font-medium { font-weight: 500; }
.font-semi   { font-weight: 600; }
.font-bold   { font-weight: 700; }

/* ── Base ───────────────────────────────────────────────────────────────────── */
body {
  background: var(--bg);
  color: var(--text);
  font-family: var(--font-main);
  font-size: 13px;
  line-height: 1.5;
  min-height: 100vh;
  transition: background 0.2s, color 0.2s;
}

/* ── Topbar (new nav) ───────────────────────────────────────────────────────── */
.topbar {
  position: fixed;
  top: 0; left: 0; right: 0;
  height: var(--nav-height);
  background: var(--nav-bg);
  border-bottom: 1px solid var(--nav-border);
  display: flex;
  align-items: center;
  padding: 0 20px;
  gap: 0;
  z-index: 1000;
  user-select: none;
}
.topbar-left {
  display: flex;
  align-items: center;
  gap: 12px;
  min-width: 220px;
  flex-shrink: 0;
}
.brand {
  display: flex;
  align-items: baseline;
  gap: 4px;
}
.brand-name {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  color: var(--accent);
  letter-spacing: 2px;
}
.brand-sub {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 500;
  color: var(--text2);
  letter-spacing: 1.5px;
}
.brand-version {
  font-size: 10px;
  color: var(--text4);
  font-family: var(--font-mono);
}
.phase-pill {
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-mono);
  letter-spacing: 1px;
  color: var(--warning);
  background: var(--warning-bg);
  border: 1px solid rgba(217,119,6,0.2);
  border-radius: var(--radius-sm);
  padding: 2px 7px;
  white-space: nowrap;
}
.topbar-tabs {
  flex: 1;
  display: flex;
  align-items: stretch;
  height: 100%;
  gap: 0;
  overflow-x: auto;
  scrollbar-width: none;
  min-width: 0;
}
.topbar-tabs::-webkit-scrollbar { display: none; }
.nav-tab {
  display: flex;
  align-items: center;
  gap: 5px;
  padding: 0 13px;
  height: 100%;
  font-size: 12px;
  font-weight: 500;
  color: var(--text3);
  cursor: pointer;
  border: none;
  background: none;
  border-bottom: 2px solid transparent;
  white-space: nowrap;
  transition: all 0.15s;
  letter-spacing: 0.3px;
  font-family: var(--font-main);
  flex-shrink: 0;
}
.nav-tab:hover { color: var(--text2); background: rgba(255,255,255,0.02); }
.nav-tab.active { color: var(--text); border-bottom-color: var(--accent); }
.tab-dot {
  width: 5px;
  height: 5px;
  border-radius: 50%;
  background: var(--text4);
  flex-shrink: 0;
}
.tab-dot.fresh, .tab-dot.green { background: var(--long); }
.tab-dot.stale, .tab-dot.amber { background: var(--neutral); }
.tab-dot.error, .tab-dot.red   { background: var(--short); }
.tab-dot.blue { background: var(--accent); }
.topbar-right {
  display: flex;
  align-items: center;
  gap: 10px;
  min-width: 200px;
  justify-content: flex-end;
  flex-shrink: 0;
}
.status-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  flex-shrink: 0;
}
.status-dot.live {
  background: var(--long);
  box-shadow: 0 0 6px var(--long);
  animation: pulse 2s ease infinite;
}
.topbar-meta {
  font-size: 10px;
  font-family: var(--font-mono);
  font-weight: 600;
  color: var(--text4);
  letter-spacing: 0.5px;
  white-space: nowrap;
}
.theme-toggle {
  width: 28px; height: 28px;
  border-radius: var(--radius);
  background: var(--surface3);
  border: 1px solid var(--border);
  color: var(--text3);
  font-size: 13px;
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  transition: all 0.15s;
  flex-shrink: 0;
}
.theme-toggle:hover { background: var(--surface2); color: var(--text); }
.topbar-time {
  font-size: 11px;
  font-family: var(--font-mono);
  color: var(--text4);
  min-width: 68px;
  text-align: right;
}

/* ── Phase bar (slim) ───────────────────────────────────────────────────────── */
.phase-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 7px 14px;
  background: rgba(217,119,6,0.05);
  border: 1px solid rgba(217,119,6,0.15);
  border-radius: var(--radius);
  margin-bottom: 16px;
  font-size: 10px;
  font-family: var(--font-mono);
  font-weight: 600;
  letter-spacing: 0.5px;
  color: var(--neutral);
}
.phase-bar-dot {
  width: 6px; height: 6px;
  border-radius: 50%;
  background: var(--neutral);
  flex-shrink: 0;
  animation: pulse 2.5s ease infinite;
}
.phase-bar-sep { color: var(--text4); }

/* ── Status bar (overview row 1) ────────────────────────────────────────────── */
.status-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.status-pill {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  font-size: 10px;
  font-family: var(--font-mono);
  font-weight: 600;
  letter-spacing: 0.3px;
  padding: 3px 8px;
  border-radius: 3px;
  border: 1px solid transparent;
}
.status-pill.ok    { background: var(--long-bg);  color: var(--long-bright); border-color: var(--long-border); }
.status-pill.warn  { background: var(--neutral-bg); color: var(--neutral);   border-color: var(--neutral-border); }
.status-pill.muted { background: var(--surface3); color: var(--text3);      border-color: var(--border); }
.status-pill-dot   { width: 5px; height: 5px; border-radius: 50%; background: currentColor; }

/* ── Metrics row ────────────────────────────────────────────────────────────── */
.metrics-row {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}
@media (max-width: 1100px) { .metrics-row { grid-template-columns: repeat(3, 1fr); } }
@media (max-width: 700px)  { .metrics-row { grid-template-columns: repeat(2, 1fr); } }
.metric-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  transition: border-color 0.15s;
}
.metric-card:hover { border-color: var(--border2); }
.mc-value {
  font-family: var(--font-mono);
  font-size: 26px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 4px;
  color: var(--text);
}
.mc-label {
  font-size: 10px;
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
}
.mc-change { font-size: 11px; font-family: var(--font-mono); margin-top: 4px; }
.mc-change.pos { color: var(--long-bright); }
.mc-change.neg { color: var(--short-bright); }

/* ── Page layout ────────────────────────────────────────────────────────────── */
.page-body {
  margin-top: var(--nav-height);
  padding: 20px 24px;
  min-height: calc(100vh - var(--nav-height));
  background: var(--bg);
  max-width: 1600px;
  margin-left: auto;
  margin-right: auto;
}
.page-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 20px;
  padding-bottom: 14px;
  border-bottom: 1px solid var(--border);
}
.page-title   { font-size: 15px; font-weight: 600; color: var(--text); letter-spacing: 0.3px; }
.page-subtitle { font-size: 11px; color: var(--text3); margin-top: 2px; }
.section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 20px 0 10px;
}
.section-hdr-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text3);
}
.section-hdr-line { flex: 1; height: 1px; background: var(--border); }
.section-hdr-count {
  font-size: 10px;
  font-family: var(--font-mono);
  color: var(--text4);
  background: var(--surface3);
  padding: 1px 7px;
  border-radius: 10px;
}

/* ── Symbol side panel ──────────────────────────────────────────────────────── */
.symbol-panel {
  position: fixed;
  top: var(--nav-height);
  right: 0;
  width: 480px;
  height: calc(100vh - var(--nav-height));
  background: var(--surface);
  border-left: 1px solid var(--border);
  z-index: 500;
  overflow-y: auto;
  transform: translateX(100%);
  transition: transform 0.25s ease;
  box-shadow: var(--shadow-lg);
}
.symbol-panel.open { transform: translateX(0); }
.symbol-panel-backdrop {
  position: fixed;
  inset: 0;
  background: rgba(0,0,0,0.3);
  z-index: 499;
  display: none;
}
.symbol-panel-backdrop.open { display: block; }
.sp-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 16px 20px;
  border-bottom: 1px solid var(--border);
  position: sticky;
  top: 0;
  background: var(--surface);
  z-index: 1;
}
.sp-symbol { font-family: var(--font-mono); font-size: 20px; font-weight: 800; color: var(--text); }
.sp-close {
  width: 28px; height: 28px;
  border-radius: var(--radius);
  background: var(--surface3);
  border: 1px solid var(--border);
  color: var(--text3);
  cursor: pointer;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 16px;
  line-height: 1;
}
.sp-close:hover { background: var(--surface2); color: var(--text); }
.sp-section { padding: 16px 20px; border-bottom: 1px solid var(--border); }
.sp-section-title {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text3);
  margin-bottom: 12px;
}
.sp-chart-wrap { width: 100%; height: 280px; border-radius: var(--radius); overflow: hidden; }
.sp-chart-wrap iframe { width: 100%; height: 100%; border: none; display: block; }

/* ── Data table system ──────────────────────────────────────────────────────── */
.table-wrapper {
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  overflow: hidden;
  overflow-x: auto;
}
.data-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.data-table thead tr { background: var(--table-head); border-bottom: 1px solid var(--table-border); }
.data-table th {
  padding: 8px 12px;
  text-align: left;
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
}
.data-table th:hover { color: var(--text2); }
.data-table th.sorted { color: var(--accent); }
.data-table th.sorted::after { content: ' ↓'; font-size: 9px; }
.data-table th.sorted.asc::after { content: ' ↑'; }
.data-table td {
  padding: 8px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  color: var(--text2);
  font-family: var(--font-mono);
  font-size: 11px;
}
[data-theme="light"] .data-table td { border-bottom: 1px solid var(--border); }
.data-table tr:hover td { background: var(--table-row-hover); }
.data-table tr.selected td { background: var(--accent-glow); }
.data-table .td-symbol { font-weight: 700; color: var(--text); font-size: 12px; }
.data-table .td-pos { color: var(--long-bright); font-weight: 600; }
.data-table .td-neg { color: var(--short-bright); font-weight: 600; }
.data-table .td-muted { color: var(--text4); }

/* ── Button system ──────────────────────────────────────────────────────────── */
.btn {
  display: inline-flex;
  align-items: center;
  gap: 6px;
  padding: 7px 14px;
  border-radius: var(--radius);
  font-size: 12px;
  font-weight: 600;
  font-family: var(--font-mono);
  cursor: pointer;
  transition: all 0.12s;
  border: 1px solid transparent;
  letter-spacing: 0.3px;
  white-space: nowrap;
}
.btn:disabled { opacity: 0.5; cursor: not-allowed; }
.btn-primary { background: var(--accent); color: #fff; border-color: var(--accent); }
.btn-primary:hover:not(:disabled) { background: #1d4ed8; box-shadow: 0 0 12px rgba(37,99,235,0.3); }
.btn-secondary { background: var(--surface3); color: var(--text2); border-color: var(--border2); }
.btn-secondary:hover:not(:disabled) { background: var(--overlay); color: var(--text); }
.btn-success { background: var(--long-bg); color: var(--long-bright); border-color: var(--long-border); }
.btn-success:hover:not(:disabled) { background: rgba(22,163,74,0.12); }
.btn-danger { background: var(--short-bg); color: var(--short-bright); border-color: var(--short-border); }
.btn-ghost { background: transparent; color: var(--text3); border-color: var(--border); }
.btn-ghost:hover:not(:disabled) { background: var(--surface3); color: var(--text2); }
.btn-sm { padding: 4px 10px; font-size: 10px; }
.btn-lg { padding: 10px 20px; font-size: 13px; }
.btn.loading { pointer-events: none; }
.btn.loading::after {
  content: '';
  width: 10px; height: 10px;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-radius: 50%;
  animation: spin 0.6s linear infinite;
  flex-shrink: 0;
}
@keyframes spin { to { transform: rotate(360deg); } }

/* ── Badge system ───────────────────────────────────────────────────────────── */
.badge {
  display: inline-flex;
  align-items: center;
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-mono);
  letter-spacing: 0.5px;
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  white-space: nowrap;
  border: 1px solid transparent;
  text-transform: uppercase;
}
.badge-active  { background: rgba(21,128,61,0.10); color: #86efac; border-color: rgba(21,128,61,0.2); }
.badge-expired { background: rgba(217,119,6,0.08); color: #fbbf24; border-color: rgba(217,119,6,0.15); }
.badge-stop-hit { background: var(--short-bg); color: var(--short-bright); border-color: var(--short-border); }
.badge-tp-hit   { background: var(--long-bg);  color: var(--long-bright);  border-color: var(--long-border); }
.badge-no-mt5   { background: var(--surface3); color: var(--text4); border-color: var(--border); font-size: 8px; padding: 1px 5px; }
.badge-delayed  { background: rgba(217,119,6,0.1); color: #fbbf24; border-color: rgba(217,119,6,0.2); font-size: 8px; padding: 1px 5px; }
.badge-live     { background: var(--long-bg); color: var(--long-bright); border-color: var(--long-border); font-size: 8px; padding: 1px 5px; }
.badge-blocked  { background: rgba(107,114,128,0.1); color: var(--text3); border-color: rgba(107,114,128,0.15); }
.badge-safety   { font-size: 8px; padding: 1px 5px; background: var(--surface3); color: var(--text4); border-color: var(--border); }
.badge-new {
  background: rgba(245,158,11,0.10); color: #fcd34d;
  border-color: rgba(245,158,11,0.2);
  animation: subtlePulse 3s ease infinite;
}
@keyframes subtlePulse { 0%,100% { opacity:1; } 50% { opacity:0.7; } }

/* ── Filter bar system ──────────────────────────────────────────────────────── */
.filter-bar {
  display: flex;
  align-items: center;
  gap: 6px;
  padding: 10px 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 14px;
  flex-wrap: wrap;
}
.filter-sep { width: 1px; height: 16px; background: var(--border2); margin: 0 4px; flex-shrink: 0; }
.filter-btn {
  padding: 4px 10px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 600;
  font-family: var(--font-mono);
  cursor: pointer;
  border: 1px solid var(--border);
  background: transparent;
  color: var(--text3);
  transition: all 0.12s;
  letter-spacing: 0.3px;
}
.filter-btn:hover { color: var(--text2); border-color: var(--border2); }
.filter-btn.active { background: var(--accent-dim); color: #60a5fa; border-color: rgba(29,78,216,0.3); }
.filter-btn.active-long, .filter-btn.long-filter.active { background: var(--long-bg); color: var(--long-bright); border-color: var(--long-border); }
.filter-btn.active-short, .filter-btn.short-filter.active { background: var(--short-bg); color: var(--short-bright); border-color: var(--short-border); }

/* ── Signal cards grid ──────────────────────────────────────────────────────── */
.signals-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
  margin-bottom: 20px;
}
@media (max-width:1200px) { .signals-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width:700px)  { .signals-grid { grid-template-columns: 1fr; } }
.signals-summary {
  font-size: 11px;
  color: var(--text3);
  font-family: var(--font-mono);
  margin-bottom: 12px;
}

.mono { font-family: var(--font-mono); }
.price {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}

/* ── Navigation bar (legacy alias — topbar is the new nav) ──────────────────── */
.nav-bar {
  background: var(--nav-bg);
  border-bottom: 1px solid var(--nav-border);
  padding: 0 20px;
  display: flex;
  align-items: center;
  gap: 0;
  height: var(--nav-height);
  position: fixed;
  top: 0; left: 0; right: 0;
  z-index: 1000;
  overflow-x: auto;
}

.nav-logo {
  font-size: 14px;
  font-weight: 700;
  color: var(--accent);
  font-family: var(--font-mono);
  letter-spacing: 1px;
  margin-right: 20px;
  white-space: nowrap;
  flex-shrink: 0;
}
.nav-logo span { color: var(--text2); font-weight: 400; }

.nav-right {
  margin-left: auto;
  display: flex;
  align-items: center;
  gap: 8px;
  flex-shrink: 0;
  padding-left: 12px;
}

.nav-pill {
  padding: 3px 8px;
  border-radius: 4px;
  font-size: 10px;
  font-family: var(--font-mono);
  font-weight: 600;
  letter-spacing: 0.5px;
  white-space: nowrap;
}
.nav-pill.safe  { background: var(--safe-bg);    color: var(--safe);   border: 1px solid rgba(0,200,83,0.2); }
.nav-pill.port  { background: var(--surface3);   color: var(--accent); border: 1px solid var(--border2); }
.nav-pill.phase { background: var(--surface3);   color: var(--muted);  border: 1px solid var(--border); }

/* ── Ticker bar ─────────────────────────────────────────────────────────────── */
.ticker-bar {
  background: var(--surface);
  border-bottom: 1px solid var(--border);
  height: 26px;
  overflow: hidden;
  position: fixed;
  top: var(--nav-height);
  left: 0; right: 0;
  z-index: 999;
}
.ticker-track {
  display: flex;
  gap: 0;
  animation: tickerScroll 60s linear infinite;
  white-space: nowrap;
  height: 100%;
  align-items: center;
}
.ticker-track:hover { animation-play-state: paused; }
@keyframes tickerScroll {
  0%   { transform: translateX(0); }
  100% { transform: translateX(-50%); }
}
.ticker-item {
  display: inline-flex;
  align-items: center;
  gap: 5px;
  padding: 0 14px;
  font-size: 10px;
  border-right: 1px solid var(--border);
  height: 100%;
  font-family: var(--font-mono);
  cursor: default;
  color: var(--text3);
}
.ticker-item.long    { color: var(--long-bright); }
.ticker-item.short   { color: var(--short-bright); }
.ticker-item.neutral { color: var(--neutral); }

/* When ticker is present, push page content down */
.has-ticker .page-content { margin-top: calc(var(--nav-height) + 26px); }

/* ── Page container ─────────────────────────────────────────────────────────── */
.page-content {
  max-width: 1600px;
  margin: 0 auto;
  padding: 20px 24px;
  margin-top: var(--nav-height);
}

/* Legacy container alias */
.container { max-width: 1600px; margin: 0 auto; padding: 20px 24px; }

/* ── Sections ───────────────────────────────────────────────────────────────── */
.section { display: none; }
.section.active { display: block; }
[id^="sec-"] { padding: 14px; }

/* ── Grid utilities ─────────────────────────────────────────────────────────── */
.grid-2 { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.grid-3 { display: grid; grid-template-columns: 1fr 1fr 1fr; gap: 16px; }
@media (max-width: 900px) { .grid-2, .grid-3 { grid-template-columns: 1fr; } }
.mb-16 { margin-bottom: 16px; }
.mb-12 { margin-bottom: 12px; }
.mb-8  { margin-bottom: 8px; }

/* ── Universal card ─────────────────────────────────────────────────────────── */
.card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 16px;
  margin-bottom: 12px;
}
.card:hover { border-color: var(--border2); }
.card-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--text3);
  margin-bottom: 12px;
}

/* ── Section headers ────────────────────────────────────────────────────────── */
.section-title {
  display: flex;
  align-items: center;
  gap: 10px;
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  margin: 0 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.section-count {
  background: var(--surface3);
  border: 1px solid var(--border2);
  border-radius: 10px;
  padding: 1px 8px;
  font-size: 11px;
  color: var(--muted);
  font-family: var(--font-mono);
}

/* ── Stat grid (overview 4-card row) ────────────────────────────────────────── */
.stat-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
@media (max-width: 900px) { .stat-grid { grid-template-columns: repeat(2, 1fr); } }

.stat-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  text-align: center;
  transition: background 0.15s, border-color 0.15s;
}
.stat-card:hover { border-color: var(--border2); background: var(--surface2); }

.stat-number {
  font-family: var(--font-mono);
  font-size: 26px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
  margin-bottom: 4px;
}
.stat-number.long  { color: var(--long); }
.stat-number.short { color: var(--short); }
.stat-number.risk-high { color: var(--danger); }
.stat-number.risk-med  { color: var(--warning); }
.stat-number.risk-low  { color: var(--safe); }
.stat-label {
  font-size: 10px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Legacy stat-box alias */
.stat-box {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  text-align: center;
}
.stat-val { font-size: 28px; font-weight: 700; color: var(--accent); font-family: var(--font-mono); }
.stat-val.ok  { color: var(--safe); }
.stat-val.bad { color: var(--danger); }
.stat-val.warn{ color: var(--warning); }
.stat-label   { font-size: 10px; color: var(--muted); margin-top: 4px; letter-spacing: 1px; text-transform: uppercase; }

/* ── Safety grid (overview) ─────────────────────────────────────────────────── */
.safety-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 8px;
  margin-bottom: 16px;
}
@media (max-width: 700px) { .safety-grid { grid-template-columns: 1fr; } }

/* ── Badges (legacy overrides — new system defined above) ───────────────────── */
.badge-exec     { background: var(--exec-bg);      color: var(--exec-text);    border: 1px solid rgba(217,119,6,0.2); }
.badge-display  { background: var(--display-bg);   color: var(--display-text); border: 1px solid rgba(37,99,235,0.2); }
.badge-research { background: var(--research-bg);  color: var(--research-text);border: 1px solid rgba(29,78,216,0.2); }
.badge-safe     { background: var(--long-bg);  color: var(--long-bright);  border: 1px solid var(--long-border); }
.badge-danger   { background: var(--short-bg); color: var(--short-bright); border: 1px solid var(--short-border); }
.badge-paper    { background: var(--paper-bg); color: var(--paper-text);   border: 1px solid rgba(202,138,4,0.3); }
.badge-long     { background: var(--long-bg);     color: var(--long-bright); border: 1px solid var(--long-border); }
.badge-short    { background: var(--short-bg);    color: var(--short-bright);border: 1px solid var(--short-border); }
.badge-neutral  { background: var(--neutral-bg);  color: var(--neutral);     border: 1px solid var(--neutral-border); }
.badge-aligned      { background: var(--long-bg);    color: var(--long-bright); border: 1px solid var(--long-border); }
.badge-conflicting  { background: var(--conflict-bg);color: var(--conflict);    border: 1px solid rgba(234,88,12,0.25); }
.badge-neutral-mac  { background: var(--surface3);   color: var(--text3);       border: 1px solid var(--border2); }

/* ── Direction badges ───────────────────────────────────────────────────────── */
.dir-badge {
  padding: 2px 7px;
  border-radius: var(--radius-sm);
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-mono);
  letter-spacing: 0.5px;
  border: 1px solid transparent;
  text-transform: uppercase;
}

/* ── Signal cards ───────────────────────────────────────────────────────────── */
.sig-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 10px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.sig-card:hover { box-shadow: var(--shadow-sm); border-color: var(--border2); }
.sig-card.long {
  border-left-color: var(--long) !important;
  background: linear-gradient(to right, var(--long-bg) 0%, var(--surface) 40%) !important;
}
.sig-card.short {
  border-left-color: var(--short) !important;
  background: linear-gradient(to right, var(--short-bg) 0%, var(--surface) 40%) !important;
}
.sig-card.neutral {
  border-left-color: var(--neutral);
}
.sig-card.conflicting {
  border-left-color: var(--conflict);
  animation: conflictPulse 2s ease-in-out infinite;
}
@keyframes conflictPulse {
  0%, 100% { box-shadow: 0 0 0 0 transparent; }
  50%       { box-shadow: 0 0 8px 2px rgba(234,88,12,0.15); }
}

.sig-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 12px;
}
.sig-header-left {
  display: flex;
  align-items: center;
  gap: 8px;
  flex-wrap: wrap;
}
.sig-symbol { font-family: var(--font-mono); font-size: 16px; font-weight: 700; color: var(--text); }
.sig-tf     { font-size: 11px; color: var(--muted); font-family: var(--font-mono); }

/* ── Price grid ─────────────────────────────────────────────────────────────── */
.price-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 8px 24px;
  margin: 10px 0 8px;
}
.price-lbl {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 2px;
}
.price-val {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 600;
  color: var(--text);
}
.price-val.entry   { color: var(--accent); }
.price-val.stop    { color: var(--short-bright); }
.price-val.tp      { color: var(--long-bright); }
.price-val.current { color: var(--text2); }

/* ── Age dots ───────────────────────────────────────────────────────────────── */
.age-dot {
  width: 6px;
  height: 6px;
  border-radius: 50%;
  display: inline-block;
  margin-right: 4px;
  vertical-align: middle;
}
.age-dot.fresh { background: var(--safe); }
.age-dot.aging { background: var(--warning); }
.age-dot.stale { background: var(--danger); animation: pulse 1.5s ease infinite; }

/* ── Rank badges ────────────────────────────────────────────────────────────── */
.rank-badge {
  width: 24px;
  height: 24px;
  border-radius: 50%;
  display: flex;
  align-items: center;
  justify-content: center;
  font-size: 11px;
  font-weight: 700;
  font-family: var(--font-mono);
  flex-shrink: 0;
}
.rank-1 { background: rgba(255,215,0,0.15); color: var(--gold);   border: 1px solid rgba(255,215,0,0.3); }
.rank-2 { background: rgba(192,192,192,0.12);color: var(--silver); border: 1px solid rgba(192,192,192,0.25); }
.rank-3 { background: rgba(205,127,50,0.12); color: var(--bronze); border: 1px solid rgba(205,127,50,0.25); }
.rank-4, .rank-5 { background: var(--surface3); color: var(--muted); border: 1px solid var(--border); }

/* ── Star ratings ───────────────────────────────────────────────────────────── */
.stars { color: var(--gold); font-size: 13px; letter-spacing: 1px; }
.stars .empty { color: var(--surface3); }

/* ── Buttons ────────────────────────────────────────────────────────────────── */
.btn {
  padding: 7px 16px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 600;
  cursor: pointer;
  border: none;
  transition: all 0.15s;
  font-family: var(--font-main);
}
.btn-primary { background: var(--accent); color: #000; }
.btn-primary:hover { background: var(--accent2); }
.btn-ghost {
  background: var(--surface2);
  color: var(--text2);
  border: 1px solid var(--border2);
}
.btn-ghost:hover { background: var(--surface3); color: var(--text); }
.btn-danger {
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid rgba(255,23,68,0.2);
}

/* Legacy refresh-btn */
.refresh-btn {
  background: var(--surface2);
  border: 1px solid var(--border2);
  color: var(--text2);
  padding: 6px 14px;
  border-radius: 6px;
  cursor: pointer;
  font-size: 12px;
  font-weight: 600;
  transition: all 0.15s;
  font-family: var(--font-main);
}
.refresh-btn:hover { background: var(--surface3); color: var(--text); }
.refresh-btn:disabled { opacity: 0.5; cursor: not-allowed; }

/* ── Button loading state ──────────────────────────────────────────────────── */
.btn-loading {
  opacity: 0.7;
  cursor: not-allowed;
  position: relative;
}
.btn-loading::after {
  content: '';
  display: inline-block;
  width: 10px;
  height: 10px;
  border: 2px solid transparent;
  border-top-color: currentColor;
  border-radius: 50%;
  animation: btnSpin 0.6s linear infinite;
  margin-left: 8px;
  vertical-align: middle;
}
@keyframes btnSpin {
  to { transform: rotate(360deg); }
}

/* ── Long-task progress bar ────────────────────────────────────────────────── */
.task-progress {
  display: flex;
  align-items: flex-start;
  gap: 10px;
  background: rgba(245,158,11,0.06);
  border: 1px solid rgba(245,158,11,0.15);
  border-radius: 6px;
  padding: 10px 12px;
  margin-top: 8px;
  font-size: 11px;
  color: var(--text2);
  line-height: 1.5;
}
.task-progress-icon {
  font-size: 16px;
  flex-shrink: 0;
  margin-top: 1px;
}
.task-progress-complete {
  background: rgba(0,200,83,0.06);
  border-color: rgba(0,200,83,0.2);
}
.task-progress-error {
  background: rgba(255,23,68,0.06);
  border-color: rgba(255,23,68,0.2);
}

/* ── Toast ──────────────────────────────────────────────────────────────────── */
#toast-container { position: fixed; bottom: 24px; right: 24px; z-index: 9999; display: flex; flex-direction: column; gap: 8px; }
.toast {
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 8px;
  padding: 12px 20px;
  font-size: 12px;
  color: var(--text);
  animation: toastIn 0.2s ease;
  max-width: 320px;
  box-shadow: 0 8px 24px rgba(0,0,0,0.5);
}
@keyframes toastIn {
  from { opacity: 0; transform: translateY(8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.toast.success { border-left: 3px solid var(--safe); }
.toast.warning { border-left: 3px solid var(--warning); }
.toast.error   { border-left: 3px solid var(--danger); }

/* ── Animations ─────────────────────────────────────────────────────────────── */
@keyframes pulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.4; }
}
.pulse-dot {
  width: 8px;
  height: 8px;
  border-radius: 50%;
  background: var(--long);
  animation: pulse 1.5s ease infinite;
  display: inline-block;
  margin-right: 6px;
  vertical-align: middle;
}

/* ── Switch cards ───────────────────────────────────────────────────────────── */
.switch-group-header {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 0 8px;
  border-bottom: 1px solid var(--border);
  margin-bottom: 12px;
}
.switch-group-title {
  font-size: 11px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--muted);
}

.switch-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 8px;
  display: flex;
  align-items: flex-start;
  justify-content: space-between;
  gap: 16px;
  transition: background 0.15s, border-color 0.15s;
}
.switch-card:hover { background: var(--surface2); border-color: var(--border2); }
.switch-card.exec     { border-left: 3px solid var(--exec-border); }
.switch-card.display  { border-left: 3px solid var(--display-border); }
.switch-card.research { border-left: 3px solid var(--research-border); }

.switch-label { font-weight: 600; font-size: 13px; margin-bottom: 4px; color: var(--text); }
.switch-desc  { font-size: 11px; color: var(--muted); }
.switch-note  { font-size: 10px; color: var(--paper-text); margin-top: 4px; font-style: italic; }

/* ── Toggle switch ──────────────────────────────────────────────────────────── */
.toggle {
  position: relative;
  width: 36px;
  height: 20px;
  flex-shrink: 0;
  margin-top: 2px;
}
.toggle input { opacity: 0; width: 0; height: 0; }
.slider, .toggle-slider {
  position: absolute;
  inset: 0;
  background: var(--surface3);
  border-radius: 20px;
  cursor: pointer;
  transition: 0.2s;
  border: 1px solid var(--border2);
}
.slider::before, .toggle-slider::before {
  content: '';
  position: absolute;
  width: 14px;
  height: 14px;
  left: 2px;
  top: 2px;
  background: var(--muted);
  border-radius: 50%;
  transition: 0.2s;
}
.toggle input:checked + .slider,
.toggle input:checked + .toggle-slider {
  background: rgba(0,200,83,0.2);
  border-color: var(--long);
}
.toggle input:checked + .slider::before,
.toggle input:checked + .toggle-slider::before {
  transform: translateX(16px);
  background: var(--long);
}
.switch-card.exec input:checked + .slider     { background: rgba(255,145,0,0.2); border-color: var(--exec-border); }
.switch-card.exec input:checked + .slider::before { background: var(--exec-border); }
.switch-card.display input:checked + .slider   { background: rgba(37,99,235,0.2); border-color: var(--display-border); }
.switch-card.display input:checked + .slider::before { background: var(--display-border); }
.switch-card.research input:checked + .slider  { background: rgba(29,78,216,0.2); border-color: var(--research-border); }
.switch-card.research input:checked + .slider::before { background: var(--research-border); }

.switch-group-desc {
  background: var(--surface2);
  border-radius: 8px;
  padding: 10px 14px;
  margin-bottom: 12px;
  font-size: 12px;
  color: var(--muted);
  border-left: 3px solid var(--border);
}
.switch-group-desc.exec     { border-left-color: var(--exec-border); }
.switch-group-desc.display  { border-left-color: var(--display-border); }
.switch-group-desc.research { border-left-color: var(--research-border); }

/* ── Production basket cards ────────────────────────────────────────────────── */
.basket-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  margin-bottom: 12px;
  transition: background 0.15s;
}
.basket-card:hover { background: var(--surface2); }
.basket-card.valid-signal  {
  border-left-color: var(--long);
  background: linear-gradient(to right, rgba(0,200,83,0.04) 0%, var(--surface) 60%);
}
.basket-card.no-signal     { border-left-color: var(--blocked); background: var(--surface); }
.basket-card.stale         { border-left-color: var(--warning); background: linear-gradient(to right, var(--warning-bg) 0%, var(--surface) 60%); }
.basket-card.not-exported  { border-left-color: var(--border2); border-style: dashed; opacity: 0.75; }

.basket-card-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 10px;
  flex-wrap: wrap;
  gap: 8px;
}
.basket-symbol   { font-size: 16px; font-weight: 700; font-family: var(--font-mono); color: var(--text); }
.basket-strategy { font-size: 11px; color: var(--muted); }
.basket-id       { font-weight: 600; font-size: 13px; color: var(--exec-text); flex: 1; }
.basket-status   { font-size: 11px; color: var(--muted); }

/* ── Display / signal cards ─────────────────────────────────────────────────── */
.display-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 10px;
  transition: border-color 0.15s, box-shadow 0.15s;
}
.display-card:hover { box-shadow: var(--shadow-sm); border-color: var(--border2); }
.display-card.dc-long {
  border-left-color: var(--long);
  background: linear-gradient(to right, var(--long-bg) 0%, var(--surface) 40%);
}
.display-card.dc-short {
  border-left-color: var(--short);
  background: linear-gradient(to right, var(--short-bg) 0%, var(--surface) 40%);
}
.display-card.dc-flat, .display-card.dc-neutral {
  border-left-color: var(--neutral);
}
.display-card.awaiting { opacity: 0.7; border-style: dashed; }

.dc-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  gap: 8px;
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.dc-header-left  { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; }
.dc-symbol       { font-size: 15px; font-weight: 700; font-family: var(--font-mono); }
.dc-tf           { font-size: 11px; color: var(--muted); font-family: var(--font-mono); }

.dc-price-grid {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 6px 20px;
  margin: 8px 0 6px;
}
.dc-price-label { font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.8px; }
.dc-price-value { font-family: var(--font-mono); font-size: 13px; font-weight: 600; color: var(--text); margin-top: 1px; }

.dc-rr { font-size: 11px; color: var(--muted); margin-bottom: 6px; font-family: var(--font-mono); }
.dc-rr strong { color: var(--text2); }

.dc-reason {
  font-size: 11px;
  color: var(--muted);
  line-height: 1.55;
  margin-bottom: 3px;
  display: -webkit-box;
  -webkit-line-clamp: 2;
  -webkit-box-orient: vertical;
  overflow: hidden;
}
.dc-reason.expanded { display: block; overflow: visible; }
.dc-reason-toggle {
  background: none;
  border: none;
  color: var(--accent);
  font-size: 10px;
  cursor: pointer;
  padding: 0;
  margin-bottom: 6px;
}
.dc-reason-toggle:hover { text-decoration: underline; }

.dc-footer {
  display: flex;
  gap: 12px;
  font-size: 10px;
  color: var(--muted);
  margin: 6px 0 8px;
  flex-wrap: wrap;
  align-items: center;
}
.dc-footer span::before { content: '· '; color: var(--border2); }
.dc-footer span:first-child::before { content: ''; }

.dc-safety, .sig-safety {
  display: flex;
  gap: 5px;
  flex-wrap: wrap;
  padding-top: 8px;
  border-top: 1px solid var(--border);
  margin-top: 8px;
}
.safety-badge {
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-family: var(--font-mono);
  background: var(--danger-bg);
  color: var(--danger);
  border: 1px solid rgba(255,23,68,0.2);
}
.safety-badge.display {
  background: var(--surface3);
  color: var(--muted);
  border-color: var(--border);
}

/* ── Display signals responsive grid ──────────────────────────────────────── */
.display-signals-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 8px;
}
@media (max-width: 1200px) {
  .display-signals-grid { grid-template-columns: repeat(2, 1fr); }
}
@media (max-width: 700px) {
  .display-signals-grid { grid-template-columns: 1fr; }
}

/* Compact card overrides inside the grid — no extra class needed on each card */
.display-signals-grid > .display-card {
  margin-bottom: 0;
  padding: 10px 12px;
}
.display-signals-grid > .display-card .dc-price-grid {
  grid-template-columns: repeat(3, 1fr);
  gap: 4px 8px;
}
.display-signals-grid > .display-card .dc-price-value { font-size: 11px; }
.display-signals-grid > .display-card .dc-symbol      { font-size: 13px; }
.display-signals-grid > .display-card .dc-header      { margin-bottom: 6px; }
.display-signals-grid > .display-card .dc-rr          { font-size: 10px; margin-bottom: 4px; }
.display-signals-grid > .display-card .dc-footer      { gap: 6px; font-size: 9px; margin: 4px 0 6px; }

/* ── Unified signals page ───────────────────────────────────────────────────── */

/* Summary bar */
.signals-summary-bar {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 16px;
  background: var(--surface);
}
.ssb-item {
  flex: 1;
  padding: 12px 8px;
  text-align: center;
  border-right: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.15s;
}
.ssb-item:last-child { border-right: none; }
.ssb-item:hover      { background: var(--surface2); }
.ssb-item.active-filter {
  background: var(--accent-glow);
  border-bottom: 2px solid var(--accent);
}
.ssb-number {
  display: block;
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 4px;
}
.ssb-number.win     { color: var(--long-bright); }
.ssb-number.loss    { color: var(--short-bright); }
.ssb-number.active  { color: var(--accent); }
.ssb-number.long    { color: var(--long-bright); }
.ssb-number.short   { color: var(--short-bright); }
.ssb-number.neutral { color: var(--text3); }
.ssb-label {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}

/* Filter bar (legacy) */
.signals-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 8px;
  padding-bottom: 8px;
}
.signals-filter-bar + .signals-filter-bar { border-top: none; }
.signals-filter-bar:last-of-type {
  border-bottom: 1px solid var(--border);
  margin-bottom: 12px;
  padding-bottom: 12px;
}

/* Per-strategy badge colours */
.badge-prod { background: var(--short-bg); color: var(--short-bright); border: 1px solid var(--short-border); }

/* Result section cards */
.sig-section-tp2  { border-left: 3px solid var(--long); background: linear-gradient(to right, rgba(0,200,83,0.10) 0%, var(--surface) 50%); }
.sig-section-tp1  { border-left: 3px solid #4ade80;     background: linear-gradient(to right, rgba(74,222,128,0.06) 0%, var(--surface) 50%); }
.sig-section-stop { border-left: 3px solid var(--short); background: linear-gradient(to right, rgba(255,23,68,0.06) 0%, var(--surface) 50%); opacity: 0.88; }
.sig-section-exp  { border-left: 3px solid var(--neutral); opacity: 0.72; }

/* Strategy-coloured left border overrides inside active grid */
.display-signals-grid > .display-card.strat-yt     { border-left-color: #3b82f6; }
.display-signals-grid > .display-card.strat-tl     { border-left-color: #8b5cf6; }
.display-signals-grid > .display-card.strat-turtle { border-left-color: #f59e0b; }
.display-signals-grid > .display-card.strat-d7     { border-left-color: #06b6d4; }
.display-signals-grid > .display-card.strat-prod   { border-left-color: #ef4444; }

/* TL Break 2 hub cards (TODO51H) — no green live styling */
.tlb2-card-audit   { border-left: 3px solid #60a5fa; background: rgba(59,130,246,0.06); }
.tlb2-card-watch   { border-left: 3px solid #94a3b8; }
.tlb2-card-moonshot { border-left: 3px solid #f59e0b; background: rgba(245,158,11,0.08); }
.tlb2-card-muted   { border-left: 3px solid #475569; opacity: 0.75; }
.tlb2-card-deploy  { border-left: 3px solid #64748b; }

/* TL Break 2 professional signal cards (TODO53) */
.tl2-sig-card {
  background: linear-gradient(145deg, rgba(15,23,42,0.95) 0%, var(--surface) 55%);
  border: 1px solid var(--border);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 10px;
  transition: border-color 0.15s, box-shadow 0.15s;
  box-shadow: 0 1px 0 rgba(255,255,255,0.03) inset;
}
.tl2-sig-card:hover { box-shadow: var(--shadow-sm); border-color: var(--border2); }
.tl2-sig-card.tl2-card-long {
  border-left: 3px solid var(--long) !important;
  background: linear-gradient(to right, var(--long-bg) 0%, rgba(15,23,42,0.92) 45%) !important;
  box-shadow: 0 0 12px rgba(34,197,94,0.06);
}
.tl2-sig-card.tl2-card-short {
  border-left: 3px solid var(--short) !important;
  background: linear-gradient(to right, var(--short-bg) 0%, rgba(15,23,42,0.92) 45%) !important;
  box-shadow: 0 0 12px rgba(239,68,68,0.06);
}
.tl2-sig-card.tl2-card-neutral { border-left: 3px solid var(--neutral); opacity: 0.9; }
.tl2-sig-card.tl2-card-moonshot {
  border-left: 3px solid #f59e0b !important;
  background: linear-gradient(to right, rgba(245,158,11,0.1) 0%, var(--surface) 45%) !important;
}
.tl2-sig-card.tl2-card-unavailable {
  border-left: 3px solid #475569 !important;
  opacity: 0.72;
  background: var(--surface2);
}
.tl2-symbol-title {
  font-family: var(--font-mono);
  font-size: 17px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: 0.02em;
}
.tl2-config-label { font-size: 10px; color: var(--muted); font-family: var(--font-mono); margin-top: 2px; }
.tl2-star-badge {
  font-size: 11px;
  letter-spacing: 1px;
  color: #fbbf24;
  padding: 1px 6px;
  border-radius: 4px;
  background: rgba(251,191,36,0.08);
  border: 1px solid rgba(251,191,36,0.2);
}
.tl2-exit-model {
  font-size: 10px;
  color: var(--muted);
  margin: 6px 0;
  padding: 6px 8px;
  border-radius: 5px;
  background: rgba(255,255,255,0.02);
  border: 1px solid var(--border);
  line-height: 1.45;
}
.tlb2-header-bar {
  display: flex;
  flex-wrap: wrap;
  align-items: center;
  gap: 6px;
  padding: 10px 14px;
  margin-bottom: 12px;
  border-radius: 8px;
  background: linear-gradient(90deg, rgba(59,130,246,0.12) 0%, rgba(15,23,42,0.4) 100%);
  border: 1px solid rgba(59,130,246,0.25);
  font-size: 11px;
  font-weight: 600;
  letter-spacing: 0.04em;
}
.tlb2-safety-panel {
  padding: 12px 14px;
  margin-bottom: 14px;
  border-radius: 8px;
  font-size: 10px;
  border: 1px solid rgba(239,68,68,0.22);
  background: rgba(15,23,42,0.6);
}
.tlb2-safety-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(110px, 1fr));
  gap: 8px;
  margin-top: 8px;
}
.tlb2-safety-item {
  padding: 6px 8px;
  border-radius: 5px;
  background: rgba(255,255,255,0.03);
  border: 1px solid var(--border);
  text-align: center;
}
.tlb2-safety-item b { display: block; font-family: var(--font-mono); font-size: 12px; margin-top: 2px; }
.tlb2-kpi-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(90px, 1fr));
  gap: 8px;
  margin-bottom: 14px;
}
.tlb2-kpi-card {
  padding: 12px 10px;
  text-align: center;
  border-radius: 8px;
  background: var(--surface2);
  border: 1px solid var(--border);
}
.tlb2-kpi-value { font-size: 20px; font-weight: 700; font-family: var(--font-mono); }
.tlb2-kpi-label { font-size: 10px; color: var(--text3); margin-top: 4px; text-transform: uppercase; letter-spacing: 0.05em; }
.tlb2-subnav { display: flex; flex-wrap: wrap; gap: 4px; margin-bottom: 12px; align-items: center; }
.tlb2-sub-btn {
  font-size: 10px;
  padding: 5px 11px;
  border-radius: 5px;
  cursor: pointer;
  background: transparent;
  border: 1px solid var(--border);
  color: var(--text2);
  font-family: inherit;
  transition: all 0.12s;
}
.tlb2-sub-btn:hover { border-color: var(--border2); color: var(--text); }
.tlb2-sub-btn.active {
  background: rgba(59,130,246,0.15);
  border-color: #3b82f6;
  color: #60a5fa;
}
.tlb2-btn-refresh {
  margin-left: auto;
  font-size: 10px;
  padding: 5px 12px;
  border-radius: 5px;
  cursor: pointer;
  background: var(--surface3);
  border: 1px solid var(--border);
  color: var(--text2);
  font-family: inherit;
}
.tlb2-btn-refresh:hover { border-color: #3b82f6; color: #93c5fd; }
.tlb2-filter-bar {
  display: flex;
  flex-wrap: wrap;
  gap: 8px;
  margin-bottom: 12px;
  padding: 10px;
  border-radius: 8px;
  background: var(--surface2);
  border: 1px solid var(--border);
}
.tlb2-filter-bar input,
.tlb2-filter-bar select {
  font-size: 10px;
  padding: 5px 8px;
  border-radius: 4px;
  background: var(--surface3);
  border: 1px solid var(--border);
  color: var(--text2);
  font-family: inherit;
  min-width: 90px;
}
.tlb2-table-wrap {
  overflow-x: auto;
  margin-top: 14px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface2);
}
.tlb2-table-wrap table { width: 100%; font-size: 10px; border-collapse: collapse; }
.tlb2-table-wrap th {
  padding: 8px 8px;
  text-align: left;
  color: var(--text3);
  font-weight: 600;
  text-transform: uppercase;
  letter-spacing: 0.04em;
  font-size: 9px;
  border-bottom: 1px solid var(--border);
  background: rgba(0,0,0,0.15);
}
.tlb2-table-wrap td {
  padding: 7px 8px;
  border-top: 1px solid rgba(255,255,255,0.04);
  font-family: var(--font-mono);
  color: var(--text2);
}
.tlb2-table-wrap tr:hover td { background: rgba(59,130,246,0.05); cursor: pointer; }
.tlb2-metric-chip {
  display: inline-block;
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  margin: 1px 2px;
  background: rgba(100,116,139,0.15);
  border: 1px solid rgba(100,116,139,0.25);
  color: var(--text2);
}
.tlb2-metric-chip.score { color: #60a5fa; border-color: rgba(96,165,250,0.3); }
.tlb2-metric-chip.risk { color: #fbbf24; border-color: rgba(251,191,36,0.25); }
.tlb2-config-card {
  padding: 12px 14px;
  border-radius: 8px;
  margin-bottom: 8px;
  cursor: pointer;
  border: 1px solid var(--border);
  background: linear-gradient(145deg, rgba(15,23,42,0.6) 0%, var(--surface) 70%);
  transition: border-color 0.12s;
}
.tlb2-config-card:hover { border-color: var(--border2); }
.tlb2-detail-panel {
  padding: 16px;
  border-radius: 8px;
  border: 1px solid var(--border);
  background: var(--surface2);
}
.tlb2-moonshot-banner {
  padding: 10px 12px;
  margin-bottom: 12px;
  border-radius: 6px;
  font-size: 11px;
  color: #fbbf24;
  background: rgba(245,158,11,0.1);
  border: 1px solid rgba(245,158,11,0.3);
}
.tlb2-section-label {
  font-size: 11px;
  font-weight: 600;
  color: var(--text2);
  margin: 14px 0 8px;
  text-transform: uppercase;
  letter-spacing: 0.06em;
}

/* Result badges */
.result-badge {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  padding: 3px 8px;
  border-radius: 4px;
}
.result-badge.tp2     { background: rgba(0,200,83,0.15);   color: var(--long);  border: 1px solid rgba(0,200,83,0.3); }
.result-badge.tp1     { background: rgba(74,222,128,0.10); color: #4ade80;      border: 1px solid rgba(74,222,128,0.25); }
.result-badge.stop    { background: rgba(255,23,68,0.12);  color: var(--short); border: 1px solid rgba(255,23,68,0.25); }
.result-badge.expired { background: rgba(255,145,0,0.10);  color: var(--neutral); border: 1px solid rgba(255,145,0,0.25); }

/* Stats panel */
.stats-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 16px;
  margin-top: 20px;
}
.stats-summary-row {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 10px;
  margin-bottom: 16px;
}
@media (max-width: 700px) {
  .stats-summary-row { grid-template-columns: repeat(3, 1fr); }
}

/* ── NEW / EXPERIMENTAL / asset-class badges ────────────────────────────────── */
@keyframes newPulse {
  0%, 100% { opacity: 1; }
  50%       { opacity: 0.55; }
}
.badge-new {
  background: rgba(245,158,11,0.15);
  color: #f59e0b;
  border: 1px solid rgba(245,158,11,0.4);
  font-size: 8px;
  font-weight: 700;
  font-family: var(--font-mono);
  padding: 1px 5px;
  border-radius: 3px;
  letter-spacing: 0.5px;
  animation: newPulse 2s ease infinite;
}
.badge-experimental {
  background: rgba(139,92,246,0.12);
  color: #8b5cf6;
  border: 1px solid rgba(139,92,246,0.3);
  font-size: 8px;
  font-weight: 700;
  font-family: var(--font-mono);
  padding: 1px 5px;
  border-radius: 3px;
  letter-spacing: 0.5px;
}

.badge-new-market {
  background: rgba(245,158,11,0.15);
  color: var(--accent);
  border: 1px solid rgba(245,158,11,0.4);
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-weight: 700;
  font-family: var(--font-mono);
  letter-spacing: 0.5px;
  animation: newPulse 3s ease infinite;
}

.new-market-warning {
  background: rgba(245,158,11,0.08);
  border: 1px solid rgba(245,158,11,0.2);
  border-radius: 5px;
  padding: 5px 10px;
  font-size: 10px;
  color: var(--accent);
  margin-bottom: 6px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Asset class badges */
.badge-ac-fx        { background: #1e3a5f; color: #60a5fa; border: 1px solid rgba(96,165,250,0.25); }
.badge-ac-equity    { background: #1f2937; color: #9ca3af; border: 1px solid rgba(156,163,175,0.2); }
.badge-ac-crypto    { background: #2d1b69; color: #a78bfa; border: 1px solid rgba(167,139,250,0.3); }
.badge-ac-commodity { background: #451a03; color: #fb923c; border: 1px solid rgba(251,146,60,0.3);  }
.badge-ac-index     { background: #083344; color: #22d3ee; border: 1px solid rgba(34,211,238,0.3);  }
.badge-ac-volatility{ background: #450a0a; color: #ef4444; border: 1px solid rgba(239,68,68,0.3);  }
.badge-ac-etf       { background: #1c2b1e; color: #4ade80; border: 1px solid rgba(74,222,128,0.25); }
.badge-ac-bond      { background: #1e293b; color: #7dd3fc; border: 1px solid rgba(125,211,252,0.25); }
.badge-ac-yield     { background: #1e1b4b; color: #a5b4fc; border: 1px solid rgba(165,180,252,0.3);  }
.badge-ac-equity-mid { background: #1c1a0d; color: #fcd34d; border: 1px solid rgba(252,211,77,0.25); }

.badge-screener {
  background: rgba(236,72,153,0.15) !important;
  color: #ec4899 !important;
  border: 1px solid rgba(236,72,153,0.3) !important;
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-weight: 700;
  font-family: var(--font-mono);
}

.badge-yield {
  background: rgba(99,102,241,0.15);
  color: #6366f1;
  border: 1px solid rgba(99,102,241,0.3);
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-weight: 700;
  font-family: var(--font-mono);
}

/* Compact delayed-data badge */
.data-quality-badge {
  font-size: 8px;
  padding: 1px 5px;
  border-radius: 3px;
  background: rgba(255,145,0,0.1);
  color: var(--warning);
  border: 1px solid rgba(255,145,0,0.2);
  font-family: var(--font-mono);
  font-weight: 700;
}

/* Entry / stop / tp price emphasis */
.dc-price-entry { font-size: 15px !important; font-weight: 700 !important; color: var(--accent) !important; }
.dc-price-stop  { color: var(--danger) !important; }
.dc-price-tp    { color: var(--safe) !important; }

/* Summary bar TP2 gold */
.ssb-number.tp2 { color: #ffd700; }
.ssb-number.tp1 { color: #4ade80; }

.yield-note {
  background: rgba(99,102,241,0.06);
  border: 1px solid rgba(99,102,241,0.2);
  border-radius: 5px;
  padding: 5px 10px;
  font-size: 10px;
  color: #a5b4fc;
  margin-bottom: 6px;
}

/* Screener tab styles */
.screener-movers-table { width: 100%; border-collapse: collapse; font-size: 11px; }
.screener-movers-table th { color: var(--muted); font-size: 10px; text-align: left; padding: 4px 8px; border-bottom: 1px solid var(--border); }
.screener-movers-table td { padding: 5px 8px; border-bottom: 1px solid var(--border); }
.screener-movers-table tr:last-child td { border-bottom: none; }
.chg-strong-up  { color: var(--safe); font-weight: 700; }
.chg-up         { color: #4ade80; }
.chg-down       { color: var(--danger); }

/* Screener "Is it too late?" status banner */
.screener-status-banner {
  border-radius: 5px;
  padding: 6px 10px;
  font-size: 10px;
  font-weight: 600;
  margin-bottom: 8px;
  display: flex;
  align-items: center;
  gap: 6px;
  line-height: 1.4;
}
.ssb-not-triggered {
  background: rgba(245,158,11,0.1);
  color: var(--warning);
  border: 1px solid rgba(245,158,11,0.2);
}
.ssb-entry-zone {
  background: rgba(0,200,83,0.1);
  color: var(--long);
  border: 1px solid rgba(0,200,83,0.2);
}
.ssb-extended {
  background: rgba(255,145,0,0.1);
  color: var(--neutral);
  border: 1px solid rgba(255,145,0,0.2);
}
.ssb-chase-risk {
  background: rgba(255,23,68,0.1);
  color: var(--short);
  border: 1px solid rgba(255,23,68,0.2);
}

/* VIX level display */
.vix-widget {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  border-radius: 6px;
  background: var(--surface2);
  border-left: 3px solid var(--border2);
  font-size: 11px;
  margin-bottom: 8px;
}
.vix-widget.low       { border-left-color: var(--safe);    }
.vix-widget.neutral   { border-left-color: var(--neutral); }
.vix-widget.warning   { border-left-color: var(--warning); }
.vix-widget.danger    { border-left-color: var(--danger);  }
.vix-number { font-family: var(--font-mono); font-size: 20px; font-weight: 700; }
.vix-label  { font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.8px; }

/* ── Data freshness banners ─────────────────────────────────────────────────── */
.freshness-banner {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 8px 14px;
  border-radius: 6px;
  font-size: 11px;
  margin-bottom: 12px;
  border: 1px solid;
  gap: 10px;
}
.freshness-banner.fresh  { background: var(--safe-bg);    border-color: rgba(0,200,83,0.2);   color: var(--safe); }
.freshness-banner.aging  { background: var(--warning-bg); border-color: rgba(255,145,0,0.2);  color: var(--warning); }
.freshness-banner.stale  { background: var(--danger-bg);  border-color: rgba(255,23,68,0.2);  color: var(--short); }

/* ── Top 5 Candidates grid ──────────────────────────────────────────────────── */
.top5-grid {
  display: grid;
  grid-template-columns: repeat(2, 1fr);
  gap: 14px;
  margin-bottom: 16px;
}
@media (max-width: 900px) {
  .top5-grid { grid-template-columns: 1fr; }
}
.top5-grid .rank-1-card { grid-column: 1 / -1; }

/* Compact candidate card */
.candidate-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  transition: border-color 0.15s, box-shadow 0.15s;
  cursor: pointer;
}
.candidate-card:hover { box-shadow: var(--shadow-sm); border-color: var(--border2); }
.candidate-card.long    { border-left-color: var(--long);    background: linear-gradient(to right, var(--long-bg)  0%, var(--surface) 40%); }
.candidate-card.short   { border-left-color: var(--short);   background: linear-gradient(to right, var(--short-bg) 0%, var(--surface) 40%); }
.candidate-card.neutral { border-left-color: var(--neutral); }
.candidate-card.conflicting { border-left-color: var(--conflict); animation: conflictPulse 2s ease-in-out infinite; }

/* Card header */
.cc-header { display: flex; align-items: center; gap: 6px; flex-wrap: wrap; margin-bottom: 10px; }
.cc-symbol  { font-family: var(--font-mono); font-size: 16px; font-weight: 700; color: var(--text); }
.cc-score   { margin-left: auto; font-family: var(--font-mono); font-size: 11px; color: var(--muted); display: flex; align-items: center; gap: 4px; }

/* Info grid */
.cc-info { display: grid; grid-template-columns: 1fr 1fr; gap: 6px 16px; margin-bottom: 10px; font-size: 11px; }
.cc-info-label { font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.6px; margin-bottom: 2px; }
.cc-info-value { color: var(--text2); line-height: 1.4; font-size: 11px; }
.cc-info-value.entry { color: var(--accent); font-family: var(--font-mono); }
.cc-info-value.stop  { color: var(--short);  font-family: var(--font-mono); }

/* Macro compact row */
.cc-macro {
  display: flex;
  gap: 12px;
  flex-wrap: wrap;
  padding: 7px 10px;
  background: var(--surface2);
  border-radius: 6px;
  margin-bottom: 8px;
  border-left: 2px solid var(--border2);
}
.cc-macro.aligned     { border-left-color: var(--long); }
.cc-macro.conflicting { border-left-color: var(--conflict); background: var(--conflict-bg); }
.cc-macro-item   { display: flex; flex-direction: column; gap: 1px; }
.cc-macro-label  { font-size: 8px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; }
.cc-macro-value  { font-size: 11px; font-weight: 600; font-family: var(--font-mono); color: var(--text2); }
.cc-macro-value.bullish { color: var(--long); }
.cc-macro-value.bearish { color: var(--short); }
.cc-macro-value.neutral { color: var(--muted); }

/* Signal date bar */
.cc-dates {
  display: flex;
  gap: 20px;
  padding: 8px 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 10px;
  flex-wrap: wrap;
}
.cc-date-item {
  display: flex;
  flex-direction: column;
  gap: 2px;
}
.cc-date-label {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.6px;
}
.cc-date-value {
  font-family: var(--font-mono);
  font-size: 11px;
  color: var(--text2);
}

/* Conflict warning */
.cc-conflict-warn {
  background: var(--conflict-bg);
  border: 1px solid rgba(255,109,0,0.25);
  border-radius: 5px;
  padding: 6px 10px;
  font-size: 10px;
  color: var(--conflict);
  margin-bottom: 8px;
}

/* News mini block */
.cc-news { margin-bottom: 8px; }
.cc-news-title { font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 4px; }
.cc-news-item {
  display: flex;
  align-items: center;
  gap: 6px;
  font-size: 10px;
  color: var(--text2);
  margin-bottom: 3px;
  overflow: hidden;
}
.cc-news-dot { width: 6px; height: 6px; border-radius: 50%; flex-shrink: 0; }
.cc-news-dot.bullish { background: var(--long); }
.cc-news-dot.bearish { background: var(--short); }
.cc-news-dot.neutral { background: var(--muted); }
.cc-news-age { margin-left: auto; color: var(--muted); font-size: 9px; flex-shrink: 0; white-space: nowrap; }

/* Safety footer */
.cc-safety { display: flex; gap: 4px; flex-wrap: wrap; padding-top: 8px; border-top: 1px solid var(--border); margin-top: 6px; }

/* Freshness banner */
.ds-freshness-banner {
  background: var(--warning-bg);
  border: 1px solid rgba(255,145,0,0.3);
  border-radius: 6px;
  padding: 6px 12px;
  font-size: 11px;
  color: var(--warning);
  margin-bottom: 10px;
  display: flex;
  align-items: center;
  gap: 6px;
}

/* Strategy section / display section headers */
.ds-section-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin: 12px 0 8px;
}
.ds-section-header-label { font-size: 13px; font-weight: 700; color: var(--text); }
.ds-count-badge {
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 10px;
  padding: 1px 8px;
  font-size: 11px;
  color: var(--muted);
  font-weight: 600;
  font-family: var(--font-mono);
}

.ds-stat-bar {
  display: flex;
  gap: 0;
  border: 1px solid var(--border);
  border-radius: 8px;
  overflow: hidden;
  margin-bottom: 10px;
}
.ds-stat-item {
  flex: 1;
  padding: 10px 12px;
  text-align: center;
  border-right: 1px solid var(--border);
}
.ds-stat-item:last-child { border-right: none; }
.ds-stat-n { display: block; font-size: 20px; font-weight: 700; color: var(--accent); font-family: var(--font-mono); }
.ds-stat-n.ok   { color: var(--safe); }
.ds-stat-n.bad  { color: var(--danger); }
.ds-stat-n.warn { color: var(--warning); }
.ds-stat-l { display: block; font-size: 10px; color: var(--muted); margin-top: 2px; text-transform: uppercase; letter-spacing: 0.4px; }

.ds-slim-card {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 8px 12px;
  background: var(--surface2);
  border-radius: 7px;
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 8px;
  border: 1px solid var(--border);
}

/* ── Research / P2 board cards ──────────────────────────────────────────────── */
.research-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 12px;
  transition: background 0.15s;
}
.research-card:hover { background: var(--surface2); }
.research-card.long    { border-left-color: var(--long);  background: linear-gradient(to right, var(--long-bg)    0%, var(--surface) 60%); }
.research-card.short   { border-left-color: var(--short); background: linear-gradient(to right, var(--short-bg)   0%, var(--surface) 60%); }
.research-card.neutral { border-left-color: var(--neutral); background: linear-gradient(to right, var(--neutral-bg) 0%, var(--surface) 60%); }
.research-card.conflicting { border-left-color: var(--conflict); animation: conflictPulse 2s ease-in-out infinite; }

.research-title   { font-weight: 600; font-size: 13px; color: var(--text); margin-bottom: 6px; }
.research-content { font-size: 12px; color: var(--muted); white-space: pre-wrap; max-height: 200px; overflow-y: auto; }

.p2-board-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 16px;
}
.p2-board-title { font-size: 13px; font-weight: 700; color: var(--text); margin-bottom: 10px; }
.p2-placeholder {
  background: var(--surface2);
  border: 1px dashed var(--border2);
  border-radius: 8px;
  padding: 16px;
  text-align: center;
  color: var(--muted);
  font-size: 12px;
  margin-bottom: 16px;
}

/* ── COT cards ──────────────────────────────────────────────────────────────── */
.cot-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 8px;
  transition: background 0.15s;
}
.cot-card:hover { background: var(--surface2); }
.cot-card.bullish  { border-left: 4px solid var(--long); }
.cot-card.bearish  { border-left: 4px solid var(--short); }
.cot-card.neutral  { border-left: 4px solid var(--neutral); }
.cot-card.missing  { border-left: 4px solid var(--blocked); opacity: 0.7; }
.cot-market { font-weight: 700; font-size: 14px; font-family: var(--font-mono); }
.cot-symbol { font-size: 11px; color: var(--muted); }
.cot-bias { font-size: 12px; font-weight: 700; font-family: var(--font-mono); }
.cot-bias.bullish { color: var(--long); }
.cot-bias.bearish { color: var(--short); }
.cot-bias.neutral { color: var(--neutral); }

/* ── Risk bar ───────────────────────────────────────────────────────────────── */
.risk-bar-outer, .risk-bar-wrap {
  background: var(--surface3);
  border-radius: 4px;
  height: 8px;
  overflow: hidden;
  margin: 6px 0;
}
.risk-bar, .risk-bar-fill {
  height: 100%;
  border-radius: 4px;
  transition: width 0.5s ease;
}
.risk-bar-fill.low,  .risk-low    { background: var(--long); }
.risk-bar-fill.med,  .risk-medium { background: var(--warning); }
.risk-bar-fill.high, .risk-high   { background: linear-gradient(to right, var(--warning), var(--danger)); }
.risk-bar-fill.extreme            { background: var(--danger); }

/* ── Scenario cards ─────────────────────────────────────────────────────────── */
.scenario-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 14px;
  margin-bottom: 8px;
  transition: background 0.15s;
}
.scenario-card.active { border-color: rgba(202,138,4,0.4); background: rgba(202,138,4,0.06); }
.scenario-active-badge {
  background: rgba(202,138,4,0.15);
  color: var(--paper-text);
  font-size: 9px;
  font-weight: 700;
  padding: 2px 7px;
  border-radius: 4px;
  text-transform: uppercase;
  font-family: var(--font-mono);
  border: 1px solid rgba(202,138,4,0.3);
}

/* ── Compact scenario list ──────────────────────────────────────────────────── */
.scenario-compact { display: flex; flex-direction: column; gap: 4px; margin-bottom: 16px; }
.scenario-row {
  display: grid;
  grid-template-columns: 130px 1fr 110px;
  gap: 10px;
  align-items: center;
  padding: 7px 12px;
  border-radius: 6px;
  font-size: 11px;
  border-left: 3px solid var(--border2);
  background: var(--surface2);
  transition: background 0.15s;
}
.scenario-row:hover { background: var(--surface3); }
.scenario-row.active { border-left-color: var(--long); background: rgba(22,163,74,0.06); }
.scenario-row.risk-off { border-left-color: var(--short); }
.scenario-row .sc-name { font-weight: 700; font-family: var(--font-mono); font-size: 10px; color: var(--text); }
.scenario-row.active .sc-name { color: var(--long-bright); }
.scenario-row.risk-off.active .sc-name { color: var(--short-bright); }
.scenario-row .sc-desc { color: var(--text3); line-height: 1.4; }
.scenario-row .sc-assets { font-size: 10px; color: var(--muted); text-align: right; font-family: var(--font-mono); }

/* ── Bias rows ──────────────────────────────────────────────────────────────── */
.bias-row {
  display: grid;
  grid-template-columns: 180px 80px 100px 1fr;
  gap: 10px;
  align-items: center;
  padding: 10px 14px;
  margin-bottom: 6px;
  background: var(--surface2);
  border-radius: 8px;
  border-left: 4px solid var(--border);
  font-size: 12px;
  transition: background 0.15s;
}
.bias-row:hover { background: var(--surface3); }
.bias-row.bullish  { border-left-color: var(--long); }
.bias-row.bearish  { border-left-color: var(--short); }
.bias-row.neutral  { border-left-color: var(--neutral); }
.bias-row.missing  { border-left-color: var(--blocked); opacity: 0.7; }
@media (max-width: 800px) { .bias-row { grid-template-columns: 1fr 80px; } }

/* ── Bias / alignment colour chips ─────────────────────────────────────────── */
.bias-bullish  { color: var(--long);    font-weight: 700; }
.bias-bearish  { color: var(--short);   font-weight: 700; }
.bias-neutral  { color: var(--neutral); font-weight: 700; }
.bias-missing  { color: var(--muted);   font-style: italic; }

/* ── Macro context block ────────────────────────────────────────────────────── */
.macro-block {
  background: var(--surface2);
  border-radius: 8px;
  padding: 10px 12px;
  margin: 8px 0;
  font-size: 11px;
}
.macro-block.conflicting { border-left: 3px solid var(--short); }
.macro-block.aligned     { border-left: 3px solid var(--long); }
.macro-block.neutral     { border-left: 3px solid var(--blocked); }

.conflict-banner {
  background: var(--conflict-bg);
  border: 1px solid rgba(255,109,0,0.25);
  border-radius: 5px;
  padding: 8px 12px;
  font-size: 11px;
  color: var(--conflict);
  margin: 8px 0;
  display: flex;
  align-items: center;
  gap: 8px;
  font-weight: 600;
}

/* ── Safety panel rows ──────────────────────────────────────────────────────── */
.safety-row {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 10px 14px;
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 6px;
  font-size: 12px;
  margin-bottom: 6px;
}
.safety-row.ok   { border-left: 3px solid var(--safe); }
.safety-row.ok .check   { color: var(--safe); }
.safety-row.lock { border-left: 3px solid var(--blocked); }
.safety-row.lock .check { color: var(--muted); }
.safety-row .check { font-size: 14px; flex-shrink: 0; }

.safety-key { flex: 1; font-size: 13px; color: var(--text2); }
.safety-val { font-weight: 700; font-family: var(--font-mono); }
.val-ok      { color: var(--safe); }
.val-blocked { color: var(--safe); }
.val-danger  { color: var(--danger); }

/* ── Journal table ──────────────────────────────────────────────────────────── */
.journal-table { width: 100%; border-collapse: collapse; font-size: 12px; }
.journal-table th {
  background: var(--surface2);
  color: var(--muted);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  padding: 8px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  font-weight: 600;
}
.journal-table td {
  padding: 10px 12px;
  border-bottom: 1px solid var(--border);
  font-family: var(--font-mono);
  font-size: 12px;
}
.journal-table tr:hover td { background: var(--surface2); }
.journal-table tr:nth-child(even) td { background: rgba(255,255,255,0.01); }
.journal-table tr.conflicting td { background: rgba(255,23,68,0.03); }
.journal-table tr.aligned td     { background: rgba(0,200,83,0.03); }
.outcome-pos, .ret-pos { color: var(--long);  font-weight: 700; }
.outcome-neg, .ret-neg { color: var(--short); font-weight: 700; }
.ret-zero { color: var(--muted); }

/* ── Generic table ──────────────────────────────────────────────────────────── */
table { width: 100%; border-collapse: collapse; font-size: 12px; }
th {
  text-align: left;
  padding: 8px 10px;
  background: var(--surface2);
  color: var(--muted);
  font-weight: 600;
  border-bottom: 1px solid var(--border);
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.5px;
}
td { padding: 8px 10px; border-bottom: 1px solid var(--border); }
tr:last-child td { border-bottom: none; }

/* ── Audit entries ──────────────────────────────────────────────────────────── */
.audit-entry {
  font-size: 11px;
  font-family: var(--font-mono);
  padding: 6px 10px;
  background: var(--surface2);
  border-radius: 4px;
  margin-bottom: 4px;
  color: var(--muted);
  border-left: 3px solid var(--border);
}
.audit-entry.exec-audit { border-color: var(--exec-border); color: var(--exec-text); }

/* ── Refresh steps ──────────────────────────────────────────────────────────── */
.refresh-step {
  display: flex;
  align-items: center;
  gap: 10px;
  padding: 6px 0;
  font-size: 12px;
}
.step-ok      { color: var(--safe); }
.step-err     { color: var(--danger); }
.step-running { color: var(--warning); font-style: italic; }

/* ── Overview control cards ─────────────────────────────────────────────────── */
.control-grid {
  display: grid;
  grid-template-columns: repeat(auto-fill, minmax(160px, 1fr));
  gap: 10px;
  margin-bottom: 16px;
}
.control-card {
  background: var(--surface2);
  border-radius: 8px;
  padding: 14px;
  text-align: center;
  border: 1px solid var(--border);
  cursor: pointer;
  transition: background 0.15s, border-color 0.15s;
}
.control-card:hover { background: var(--surface3); border-color: var(--border2); }
.control-card.locked  { border-color: rgba(255,23,68,0.3); }
.control-card.safe    { border-color: rgba(0,200,83,0.3); }
.control-card.off     { border-color: var(--border); }
.control-card-label   { font-size: 9px; color: var(--muted); margin-bottom: 6px; text-transform: uppercase; letter-spacing: 0.5px; }
.control-card-value   { font-size: 16px; font-weight: 700; margin-bottom: 8px; font-family: var(--font-mono); }
.control-card-value.ok     { color: var(--safe); }
.control-card-value.danger { color: var(--danger); }
.control-card-value.muted  { color: var(--muted); }
.control-locked-btn {
  display: block;
  width: 100%;
  padding: 5px 8px;
  background: var(--surface3);
  border: 1px solid var(--border2);
  color: var(--muted);
  border-radius: 5px;
  cursor: not-allowed;
  font-size: 9px;
  font-weight: 700;
  letter-spacing: 0.5px;
  font-family: var(--font-mono);
}
.control-safe-btn {
  display: block;
  width: 100%;
  padding: 5px 8px;
  background: var(--safe-bg);
  border: 1px solid rgba(0,200,83,0.3);
  color: var(--safe);
  border-radius: 5px;
  cursor: default;
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-mono);
}

/* ── Breaking news ──────────────────────────────────────────────────────────── */
.news-bell {
  position: relative;
  cursor: pointer;
  font-size: 16px;
  padding: 4px 8px;
  border-radius: 6px;
  transition: background 0.15s;
  flex-shrink: 0;
  line-height: 1;
}
.news-bell:hover { background: var(--surface2); }

.bell-badge {
  position: absolute;
  top: -2px;
  right: -2px;
  background: var(--short);
  color: #fff;
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-mono);
  border-radius: 10px;
  padding: 1px 5px;
  min-width: 16px;
  text-align: center;
  line-height: 1.4;
}
.bell-badge.pulse { animation: bellPulse 1s ease infinite; }
@keyframes bellPulse {
  0%, 100% { transform: scale(1); }
  50%       { transform: scale(1.3); }
}

.breaking-toast {
  position: fixed;
  top: 60px;
  right: 16px;
  background: var(--surface2);
  border: 1px solid var(--short);
  border-left: 4px solid var(--short);
  border-radius: 8px;
  padding: 14px 18px;
  max-width: 360px;
  z-index: 9999;
  animation: toastSlideIn 0.3s ease;
  box-shadow: 0 4px 20px rgba(255,23,68,0.2);
}
@keyframes toastSlideIn {
  from { opacity: 0; transform: translateX(20px); }
  to   { opacity: 1; transform: translateX(0); }
}
.breaking-toast .bt-label {
  font-size: 9px;
  font-weight: 700;
  color: var(--short);
  font-family: var(--font-mono);
  letter-spacing: 1px;
  margin-bottom: 6px;
}
.breaking-toast .bt-title {
  font-size: 13px;
  color: var(--text);
  font-weight: 600;
  line-height: 1.4;
  margin-bottom: 8px;
}
.breaking-toast .bt-markets {
  font-size: 11px;
  color: var(--muted);
  margin-bottom: 10px;
}
.breaking-toast .bt-actions { display: flex; gap: 8px; }
.bt-view-btn {
  font-size: 11px; padding: 4px 10px;
  background: var(--danger-bg); color: var(--short);
  border: 1px solid rgba(255,23,68,0.3); border-radius: 4px; cursor: pointer;
}
.bt-dismiss-btn {
  font-size: 11px; padding: 4px 10px;
  background: var(--surface3); color: var(--muted);
  border: 1px solid var(--border); border-radius: 4px; cursor: pointer;
}

.news-card.breaking { box-shadow: 0 0 12px rgba(255,23,68,0.15); }
.breaking-label {
  display: inline-block;
  background: var(--danger-bg);
  color: var(--short);
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-mono);
  padding: 2px 6px;
  border-radius: 3px;
  border: 1px solid rgba(255,23,68,0.3);
  margin-right: 6px;
  letter-spacing: 0.5px;
  vertical-align: middle;
}

/* ── News feed ──────────────────────────────────────────────────────────────── */
.news-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-left: 3px solid var(--neutral);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 8px;
  cursor: pointer;
  transition: background 0.15s, box-shadow 0.15s;
  user-select: none;
}
.news-card:hover {
  background: var(--surface2);
  box-shadow: 0 2px 8px rgba(0,0,0,0.3);
}
.news-card.bullish { border-left-color: var(--long); }
.news-card.bearish { border-left-color: var(--short); }
.news-card.neutral { border-left-color: var(--neutral); }

.news-filter-btn {
  padding: 5px 12px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface2);
  color: var(--text2);
  transition: all 0.15s;
  font-family: var(--font-main);
}
.news-filter-btn:hover { background: var(--surface3); color: var(--text); }
.news-filter-btn.active {
  background: var(--accent-glow);
  color: var(--accent);
  border-color: var(--accent);
}

.news-implication {
  background: var(--surface3);
  border: 1px solid var(--accent-glow);
  border-radius: 6px;
  padding: 10px 12px;
  margin-bottom: 10px;
}
.news-implication-label {
  font-size: 10px;
  font-weight: 700;
  color: var(--accent);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 4px;
}
.news-implication-text {
  font-size: 12px;
  color: var(--text2);
  line-height: 1.6;
}

.news-market-bar {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 8px;
}
.news-market-bar-fill {
  flex: 1;
  height: 5px;
  background: var(--surface3);
  border-radius: 3px;
  overflow: hidden;
}
.news-market-bar-inner {
  height: 100%;
  background: var(--accent);
  border-radius: 3px;
}

/* ── Misc ───────────────────────────────────────────────────────────────────── */
.loading { color: var(--muted); font-style: italic; font-size: 12px; padding: 8px 0; }
.error-text { color: var(--danger); font-size: 12px; }
.placeholder-text { color: var(--muted); font-size: 12px; padding: 16px; text-align: center; }
.basket-block { background: var(--danger-bg); border: 1px solid rgba(255,23,68,0.3); color: var(--danger); padding: 2px 8px; border-radius: 4px; font-size: 10px; font-weight: 700; font-family: var(--font-mono); }

/* ── Flow & Options Activity ─────────────────────────────────────────────────── */
@keyframes goldPulse {
  0%, 100% { box-shadow: 0 0 0 0 transparent; }
  50%       { box-shadow: 0 0 12px 2px rgba(255,215,0,0.2); }
}
.triple-confirm-card {
  border: 2px solid var(--gold);
  background: rgba(255,215,0,0.05);
  border-radius: 8px;
  padding: 14px;
  margin-bottom: 10px;
  animation: goldPulse 3s ease infinite;
}
.triple-confirm-card .tc-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 8px;
}
.triple-confirm-badge {
  background: rgba(255,215,0,0.15);
  color: var(--gold);
  border: 1px solid rgba(255,215,0,0.4);
  font-size: 9px; padding: 2px 6px; border-radius: 3px;
  font-weight: 700; font-family: var(--font-mono);
}
.flow-option-card {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px 20px;
  margin-bottom: 12px;
  transition: background 0.15s;
}
.flow-option-card:hover { background: var(--surface2); }
.flow-option-card.bullish { border-left: 4px solid var(--long); }
.flow-option-card.bearish { border-left: 4px solid var(--short); }
.flow-option-card.mega-whale {
  border: 2px solid var(--gold);
  background: rgba(255,215,0,0.03);
}
.flow-option-card.mega-whale:hover { background: rgba(255,215,0,0.05); }
.flow-option-card .fo-header {
  display: flex; align-items: center; gap: 8px; margin-bottom: 12px; flex-wrap: wrap;
}

.flow-numbers-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 8px;
  margin-bottom: 10px;
  padding: 12px;
  background: var(--surface2);
  border-radius: 8px;
}
.flow-numbers-grid .fn-label {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 3px;
}
.flow-numbers-grid .fn-value {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}

.flow-score-bar {
  height: 4px; background: var(--surface3); border-radius: 2px; overflow: hidden;
}
.flow-score-fill { height: 100%; border-radius: 2px; transition: width 0.3s; }

.flow-explanation {
  background: var(--surface2);
  border-radius: 6px;
  padding: 12px 14px;
  margin: 10px 0 8px;
  font-size: 12px;
  line-height: 1.6;
  border-left: 3px solid var(--border2);
}
.flow-explanation.bullish { border-left-color: var(--long); }
.flow-explanation.bearish { border-left-color: var(--short); }
.flow-explanation h4 {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--muted);
  margin: 0 0 6px 0;
  font-weight: 700;
}
.flow-explanation p { margin: 0; color: var(--text2); }

.flow-positioning {
  background: rgba(245,158,11,0.06);
  border: 1px solid rgba(245,158,11,0.2);
  border-radius: 6px;
  padding: 10px 14px;
  margin-bottom: 8px;
  font-size: 12px;
}
.flow-positioning h4 {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--accent);
  margin: 0 0 6px 0;
  font-weight: 700;
}
.flow-positioning p { margin: 0; color: var(--text2); line-height: 1.6; }

.flow-checklist { display: flex; gap: 6px; flex-wrap: wrap; margin: 8px 0; }
.flow-check-item {
  display: flex;
  align-items: center;
  gap: 4px;
  font-size: 10px;
  padding: 3px 8px;
  border-radius: 4px;
  background: var(--surface3);
  border: 1px solid var(--border);
  color: var(--muted);
}
.flow-check-item.confirmed {
  background: var(--safe-bg);
  border-color: rgba(0,200,83,0.2);
  color: var(--safe);
}
.flow-check-item.conflicts {
  background: var(--danger-bg);
  border-color: rgba(255,23,68,0.2);
  color: var(--short);
}
.flow-check-item.neutral { color: var(--muted); }

.flow-expiry-warning {
  background: var(--warning-bg);
  border: 1px solid rgba(255,145,0,0.2);
  border-radius: 5px;
  padding: 8px 12px;
  font-size: 11px;
  color: var(--warning);
  margin-bottom: 8px;
}

.sentiment-bar {
  display: flex; height: 10px; border-radius: 5px; overflow: hidden; margin: 8px 0;
}
.sentiment-bar .bull { background: var(--safe); }
.sentiment-bar .bear { background: var(--danger); }

.flow-section-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  padding: 10px 0 8px;
  border-top: 1px solid var(--border);
  margin: 8px 0 12px;
}
.flow-section-header .fsh-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  letter-spacing: 0.3px;
  display: flex;
  align-items: center;
  gap: 8px;
}
.flow-section-header .fsh-count {
  font-family: var(--font-mono);
  font-size: 12px;
  color: var(--accent);
  background: var(--surface2);
  padding: 1px 7px;
  border-radius: 10px;
  border: 1px solid var(--border2);
}

.flow-stats-row {
  display: flex;
  flex-wrap: wrap;
  gap: 6px;
  margin-bottom: 14px;
}
.flow-stat-chip {
  display: flex;
  flex-direction: column;
  align-items: center;
  padding: 6px 12px;
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  cursor: pointer;
  transition: border-color 0.15s;
  min-width: 70px;
}
.flow-stat-chip:hover { border-color: var(--accent); }
.flow-stat-chip.active { border-color: var(--accent); background: var(--accent-glow); }
.flow-stat-chip .fsc-num {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
  line-height: 1;
}
.flow-stat-chip .fsc-label {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-top: 2px;
  text-align: center;
}

.flow-filter-bar { display: flex; flex-wrap: wrap; gap: 5px; margin-bottom: 10px; }
.flow-filter-btn {
  padding: 3px 9px; border-radius: 4px; font-size: 10px; font-family: var(--font-mono);
  background: var(--surface2); border: 1px solid var(--border); color: var(--muted);
  cursor: pointer;
}
.flow-filter-btn.active { background: var(--accent); color: var(--bg); border-color: var(--accent); }

.vol-spike-table { width: 100%; border-collapse: collapse; font-size: 11px; }
.vol-spike-table th { color: var(--muted); font-size: 10px; text-align: left; padding: 4px 8px; border-bottom: 1px solid var(--border); }
.vol-spike-table td { padding: 5px 8px; border-bottom: 1px solid var(--border); }
.vol-spike-table tr:last-child td { border-bottom: none; }
.vol-ratio-extreme { color: var(--danger); font-weight: 700; }
.vol-ratio-unusual { color: var(--warning); font-weight: 600; }
.vol-ratio-notable  { color: var(--text2); }

.pcr-table { width: 100%; border-collapse: collapse; font-size: 11px; }
.pcr-table th { color: var(--muted); font-size: 10px; text-align: left; padding: 4px 8px; border-bottom: 1px solid var(--border); }
.pcr-table td { padding: 5px 8px; border-bottom: 1px solid var(--border); }
.pcr-table tr:last-child td { border-bottom: none; }
.pcr-bull { color: var(--safe); }
.pcr-bear { color: var(--danger); }

/* ── Options Expiration Calendar ─────────────────────────────────────────────── */
.options-calendar {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  margin-bottom: 20px;
}
.cal-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
}
.cal-month-title {
  font-family: var(--font-mono);
  font-size: 16px;
  font-weight: 700;
  color: var(--text);
}
.cal-nav-btn {
  background: var(--surface2);
  border: 1px solid var(--border2);
  border-radius: 6px;
  padding: 6px 12px;
  color: var(--text2);
  cursor: pointer;
  font-size: 13px;
  transition: all 0.15s;
}
.cal-nav-btn:hover { background: var(--surface3); color: var(--text); }

.cal-dow-row {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
  margin-bottom: 4px;
}
.cal-dow {
  text-align: center;
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  padding: 4px 0;
}
.cal-grid {
  display: grid;
  grid-template-columns: repeat(7, 1fr);
  gap: 4px;
}
.cal-day {
  min-height: 72px;
  border-radius: 8px;
  padding: 6px;
  cursor: pointer;
  transition: all 0.15s;
  position: relative;
  border: 1px solid transparent;
}
.cal-day:hover { border-color: var(--accent); transform: scale(1.02); z-index: 1; }
.cal-day.empty { background: transparent; cursor: default; min-height: 72px; border: none; }
.cal-day.today { border: 2px solid var(--accent) !important; }
.cal-day.strong-bullish { background: rgba(0,200,83,0.15); border-color: rgba(0,200,83,0.3); }
.cal-day.bullish         { background: rgba(0,200,83,0.08); border-color: rgba(0,200,83,0.15); }
.cal-day.neutral         { background: var(--surface2);    border-color: var(--border); }
.cal-day.bearish         { background: rgba(255,23,68,0.08); border-color: rgba(255,23,68,0.15); }
.cal-day.strong-bearish  { background: rgba(255,23,68,0.15); border-color: rgba(255,23,68,0.3); }
.cal-day.no-activity     { background: var(--surface); opacity: 0.45; cursor: default; }
.cal-day.selected        { border: 2px solid var(--accent) !important; box-shadow: 0 0 12px rgba(245,158,11,0.2); }

.cal-day-num {
  font-family: var(--font-mono);
  font-size: 13px;
  font-weight: 700;
  color: var(--text);
  margin-bottom: 3px;
}
.cal-day.today .cal-day-num { color: var(--accent); }
.cal-day-premium {
  font-family: var(--font-mono);
  font-size: 10px;
  font-weight: 600;
  margin-bottom: 2px;
  white-space: nowrap;
}
.cal-day.strong-bullish .cal-day-premium,
.cal-day.bullish .cal-day-premium         { color: var(--long); }
.cal-day.bearish .cal-day-premium,
.cal-day.strong-bearish .cal-day-premium  { color: var(--short); }
.cal-day.neutral .cal-day-premium         { color: var(--muted); }

.cal-day-bar {
  position: absolute;
  bottom: 4px;
  left: 6px;
  right: 6px;
  height: 3px;
  border-radius: 2px;
  overflow: hidden;
  display: flex;
}
.cal-day-bar-calls { background: var(--long); }
.cal-day-bar-puts  { background: var(--short); }

.cal-day-icons { display: flex; gap: 2px; flex-wrap: wrap; margin-bottom: 2px; font-size: 11px; }

.cal-intensity {
  position: absolute;
  top: 6px;
  right: 6px;
  width: 7px;
  height: 7px;
  border-radius: 50%;
}
.cal-intensity.extreme { background: var(--gold); animation: goldPulse 2s infinite; }
.cal-intensity.high    { background: var(--short); }
.cal-intensity.medium  { background: var(--warning); }
.cal-intensity.low     { background: var(--muted); opacity: 0.5; }

/* Calendar legend */
.cal-legend {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
  padding: 12px 0;
  border-top: 1px solid var(--border);
  margin-top: 12px;
  font-size: 10px;
  color: var(--muted);
}
.cal-legend-item { display: flex; align-items: center; gap: 5px; }
.cal-legend-dot  { width: 10px; height: 10px; border-radius: 3px; }

/* Calendar detail panel */
.cal-detail-panel {
  background: var(--surface);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  margin-top: 12px;
  animation: fadeIn 0.2s ease;
}
@keyframes fadeIn {
  from { opacity: 0; transform: translateY(-8px); }
  to   { opacity: 1; transform: translateY(0); }
}
.cal-detail-header {
  display: flex;
  align-items: center;
  justify-content: space-between;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.cal-detail-date {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 700;
  color: var(--text);
}
.cal-detail-summary {
  display: flex;
  gap: 16px;
  flex-wrap: wrap;
  font-size: 12px;
  margin-bottom: 14px;
  padding: 12px;
  background: var(--surface2);
  border-radius: 8px;
}
.cal-ds-item { text-align: center; }
.cal-ds-label { font-size: 9px; color: var(--muted); text-transform: uppercase; letter-spacing: 0.5px; margin-bottom: 2px; }
.cal-ds-value { font-family: var(--font-mono); font-size: 15px; font-weight: 700; color: var(--text); }

.cal-cp-bar-wrap { margin: 10px 0 14px; }
.cal-cp-bar { height: 8px; border-radius: 4px; overflow: hidden; display: flex; margin: 6px 0; }

.cal-planning-note {
  background: rgba(245,158,11,0.06);
  border: 1px solid rgba(245,158,11,0.2);
  border-radius: 6px;
  padding: 12px 14px;
  font-size: 12px;
  color: var(--text2);
  line-height: 1.6;
  margin-bottom: 14px;
}
.cal-planning-note strong { color: var(--accent); }

/* Upcoming whales widget */
.upcoming-whales {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 16px;
}
.uw-title {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px;
}
.uw-row {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 6px 4px;
  border-bottom: 1px solid var(--border);
  cursor: pointer;
  font-size: 11px;
  border-radius: 4px;
  transition: background 0.12s;
}
.uw-row:last-child { border-bottom: none; }
.uw-row:hover { background: var(--surface3); padding-left: 8px; }
.uw-date    { font-family: var(--font-mono); color: var(--text2); min-width: 64px; }
.uw-icons   { font-size: 12px; min-width: 24px; }
.uw-desc    { color: var(--text2); flex: 1; }
.uw-premium { font-family: var(--font-mono); font-weight: 700; color: var(--gold); }

/* === SIGNALS PAGE OVERRIDE === */
.sig-card {
  border-left: 3px solid var(--border2);
  border-radius: var(--radius-lg);
  padding: 14px 16px;
  margin-bottom: 10px;
  background: var(--surface);
  transition: border-color 0.15s, box-shadow 0.15s;
}
.sig-card:hover { box-shadow: var(--shadow-sm); }
.sig-card.long {
  border-left-color: var(--long);
  background: linear-gradient(to right, var(--long-bg) 0%, var(--surface) 40%);
}
.sig-card.short {
  border-left-color: var(--short);
  background: linear-gradient(to right, var(--short-bg) 0%, var(--surface) 40%);
}
.sig-card.neutral { border-left-color: var(--neutral); }
.dir-badge.long  { background: var(--long-bg);  color: var(--long-bright); border: 1px solid var(--long-border); }
.dir-badge.short { background: var(--short-bg); color: var(--short-bright); border: 1px solid var(--short-border); }
.dir-badge.neutral { background: var(--neutral-bg); color: var(--neutral); border: 1px solid var(--neutral-border); }
.badge-yt     { background: rgba(29,78,216,0.12);  color: #60a5fa; border: 1px solid rgba(29,78,216,0.2); }
.badge-tl     { background: rgba(124,58,237,0.12); color: #a78bfa; border: 1px solid rgba(124,58,237,0.2); }
.badge-turtle { background: rgba(180,83,9,0.12);   color: #fbbf24; border: 1px solid rgba(180,83,9,0.2); }
.badge-d7     { background: rgba(6,182,212,0.10);  color: #67e8f9; border: 1px solid rgba(6,182,212,0.15); }
.badge-screener { background: rgba(236,72,153,0.10); color: #f9a8d4; border: 1px solid rgba(236,72,153,0.15); }
.badge-gaps   { background: rgba(16,185,129,0.10); color: #6ee7b7; border: 1px solid rgba(16,185,129,0.15); }

/* === GAPS TAB === */

.gaps-control-bar {
  display: flex;
  align-items: center;
  gap: 12px;
  padding: 12px 0;
  border-bottom: 1px solid var(--border);
  margin-bottom: 16px;
  flex-wrap: wrap;
}
.gaps-last-scan {
  font-size: 11px;
  color: var(--muted);
  font-family: var(--font-mono);
}
.gaps-scan-btn {
  background: var(--long-bg);
  color: var(--long-bright);
  border: 1px solid var(--long-border);
  border-radius: 6px;
  padding: 8px 16px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  font-family: var(--font-mono);
  transition: all 0.15s;
  letter-spacing: 0.5px;
}
.gaps-scan-btn:hover {
  background: rgba(22,163,74,0.15);
  box-shadow: 0 0 10px rgba(22,163,74,0.12);
}
.gaps-scan-btn:disabled {
  opacity: 0.5;
  cursor: not-allowed;
}
.gaps-market-bar {
  display: grid;
  grid-template-columns: repeat(6, 1fr);
  gap: 8px;
  margin-bottom: 20px;
}
.gmb-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px;
  text-align: center;
}
.gmb-number {
  font-family: var(--font-mono);
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 4px;
  display: block;
}
.gmb-number.up { color: #00c853; }
.gmb-number.down { color: #ff1744; }
.gmb-number.neutral { color: #ff9100; }
.gmb-number.accent { color: #f59e0b; }
.gmb-label {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.gaps-filter-bar {
  display: flex;
  gap: 6px;
  flex-wrap: wrap;
  margin-bottom: 16px;
  padding-bottom: 12px;
  border-bottom: 1px solid var(--border);
}
.gfb-btn {
  padding: 5px 12px;
  border-radius: 20px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface2);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.gfb-btn:hover { color: var(--text); border-color: var(--accent); }
.gfb-btn.active {
  background: rgba(245,158,11,0.12);
  color: #f59e0b;
  border-color: rgba(245,158,11,0.4);
}
.gfb-btn.up-active {
  background: rgba(0,200,83,0.12);
  color: #00c853;
  border-color: rgba(0,200,83,0.35);
}
.gfb-btn.down-active {
  background: rgba(255,23,68,0.12);
  color: #ff1744;
  border-color: rgba(255,23,68,0.35);
}
.gaps-section-header {
  display: flex;
  align-items: center;
  gap: 10px;
  margin: 20px 0 12px;
  padding-bottom: 8px;
  border-bottom: 1px solid var(--border);
}
.gsh-title {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--text2);
}
.gsh-title.up { color: #00c853; }
.gsh-title.down { color: #ff1744; }
.gsh-title.amber { color: #f59e0b; }
.gsh-count {
  background: var(--surface3);
  color: var(--muted);
  font-size: 10px;
  font-family: var(--font-mono);
  padding: 2px 8px;
  border-radius: 10px;
}
.gsh-line { flex: 1; height: 1px; background: var(--border); }
.gaps-top-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 24px;
}
@media (max-width: 1100px) { .gaps-top-grid { grid-template-columns: repeat(2, 1fr); } }
@media (max-width: 700px) { .gaps-top-grid { grid-template-columns: 1fr; } }
.gap-setup-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  transition: all 0.15s;
  position: relative;
}
.gap-setup-card:hover {
  background: var(--surface3);
  border-color: var(--border2);
  transform: translateY(-1px);
  box-shadow: 0 4px 16px rgba(0,0,0,0.3);
}
.gap-setup-card.gap-up {
  border-left: 4px solid var(--long);
  background: linear-gradient(135deg, var(--long-bg) 0%, var(--surface2) 50%);
}
.gap-setup-card.gap-down {
  border-left: 4px solid var(--short);
  background: linear-gradient(135deg, var(--short-bg) 0%, var(--surface2) 50%);
}
.gap-setup-card.gap-reversal {
  border: 2px solid #f59e0b;
  background: linear-gradient(135deg, rgba(245,158,11,0.06) 0%, var(--surface2) 50%);
}
.gap-setup-card.gap-reversal::before {
  content: '★ A+ SETUP';
  position: absolute;
  top: -1px;
  right: 12px;
  background: #f59e0b;
  color: #000;
  font-size: 8px;
  font-weight: 800;
  padding: 2px 8px;
  border-radius: 0 0 6px 6px;
  letter-spacing: 1px;
  font-family: var(--font-mono);
}
.gsc-header {
  display: flex;
  align-items: center;
  gap: 8px;
  margin-bottom: 12px;
  flex-wrap: wrap;
}
.gsc-symbol {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  color: var(--text);
  letter-spacing: 0.5px;
}
.gsc-gap-pct {
  font-family: var(--font-mono);
  font-size: 14px;
  font-weight: 700;
  margin-left: auto;
}
.gsc-gap-pct.up { color: #00c853; }
.gsc-gap-pct.down { color: #ff1744; }
.badge-large-cap {
  background: rgba(59,130,246,0.15);
  color: #3b82f6;
  border: 1px solid rgba(59,130,246,0.3);
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
}
.badge-mid-cap {
  background: rgba(139,92,246,0.15);
  color: #8b5cf6;
  border: 1px solid rgba(139,92,246,0.3);
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
}
.badge-small-cap {
  background: rgba(236,72,153,0.15);
  color: #ec4899;
  border: 1px solid rgba(236,72,153,0.3);
  font-size: 9px;
  padding: 2px 6px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
}
.badge-pattern {
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
  letter-spacing: 0.3px;
}
.badge-gap-reversal {
  background: rgba(245,158,11,0.15);
  color: #f59e0b;
  border: 1px solid rgba(245,158,11,0.3);
}
.badge-p1 {
  background: rgba(0,200,83,0.12);
  color: #00c853;
  border: 1px solid rgba(0,200,83,0.25);
}
.badge-p2 {
  background: rgba(6,182,212,0.12);
  color: #06b6d4;
  border: 1px solid rgba(6,182,212,0.25);
}
.badge-p3 {
  background: rgba(255,145,0,0.12);
  color: #ff9100;
  border: 1px solid rgba(255,145,0,0.25);
}
.badge-earnings {
  background: rgba(255,23,68,0.12);
  color: #ff1744;
  border: 1px solid rgba(255,23,68,0.25);
  animation: earnPulse 2s ease infinite;
}
@keyframes earnPulse {
  0%,100% { opacity: 1; }
  50% { opacity: 0.6; }
}
.gsc-technicals {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 6px;
  margin-bottom: 12px;
  padding: 10px;
  background: var(--surface);
  border-radius: 6px;
  border: 1px solid var(--border);
}
.gsc-tech-item { text-align: center; }
.gsc-tech-label {
  font-size: 8px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  margin-bottom: 3px;
}
.gsc-tech-value {
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 600;
}
.gsc-tech-value.above { color: #00c853; }
.gsc-tech-value.below { color: #ff1744; }
.gsc-tech-value.neutral { color: var(--muted); }
.gsc-levels { margin-bottom: 12px; }
.gsc-level-row {
  display: flex;
  justify-content: space-between;
  align-items: flex-start;
  padding: 5px 0;
  border-bottom: 1px solid var(--border);
  gap: 8px;
}
.gsc-level-row:last-child { border-bottom: none; }
.gsc-level-label {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  min-width: 50px;
  padding-top: 1px;
}
.gsc-level-text {
  font-size: 10px;
  color: var(--text2);
  text-align: right;
  line-height: 1.4;
  flex: 1;
}
.gsc-level-text.entry { color: #f59e0b; }
.gsc-level-text.stop { color: #ff1744; }
.gsc-level-text.target { color: #00c853; }
.gsc-score {
  display: flex;
  align-items: center;
  gap: 6px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
  margin-top: 8px;
}
.gsc-stars { color: #f59e0b; font-size: 11px; letter-spacing: 1px; }
.gsc-score-num { font-family: var(--font-mono); font-size: 10px; color: var(--muted); }
.gsc-volume { margin-left: auto; font-family: var(--font-mono); font-size: 10px; color: var(--muted); }
.gsc-volume.spike { color: #f59e0b; font-weight: 700; }
.gaps-table-wrapper {
  overflow-x: auto;
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-bottom: 20px;
}
.gaps-table {
  width: 100%;
  border-collapse: collapse;
  font-size: 12px;
  font-family: var(--font-mono);
}
.gaps-table th {
  background: var(--surface3);
  color: var(--muted);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 10px 12px;
  text-align: left;
  border-bottom: 1px solid var(--border);
  white-space: nowrap;
  cursor: pointer;
  user-select: none;
}
.gaps-table th:hover { color: var(--text); }
.gaps-table th.sorted { color: #f59e0b; }
.gaps-table td {
  padding: 9px 12px;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  white-space: nowrap;
  color: var(--text2);
}
.gaps-table tr:hover td { background: rgba(245,158,11,0.04); }
.gaps-table tr.selected td {
  background: rgba(245,158,11,0.07);
  border-left: 2px solid #f59e0b;
}
.td-gap.up { color: #00c853; font-weight: 700; }
.td-gap.down { color: #ff1744; font-weight: 700; }
.td-gap.flat { color: var(--muted); }
.td-vol.spike { color: #f59e0b; font-weight: 700; }
.td-sma.above { color: #00c853; }
.td-sma.below { color: #ff1744; }
.td-pattern { font-size: 10px; }
.td-symbol { color: var(--text); font-weight: 700; font-size: 13px; }
.gaps-disclaimer {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-left: 3px solid var(--muted);
  border-radius: 6px;
  padding: 10px 14px;
  font-size: 10px;
  color: var(--muted);
  margin-top: 20px;
  line-height: 1.6;
}

/* === GAPS TAB ENHANCEMENTS === */

/* Context panel */
.gaps-context-panel {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-left: 4px solid var(--accent);
  border-radius: 8px;
  padding: 14px 18px;
  margin-bottom: 16px;
}
.gcp-title {
  font-family: var(--font-mono);
  font-size: 12px;
  font-weight: 800;
  letter-spacing: 1px;
  margin-bottom: 8px;
}
.gcp-text {
  font-size: 11px;
  color: var(--text2);
  line-height: 1.7;
}

/* Expandable table rows */
.gap-data-row { cursor: pointer; }
.gap-data-row:hover td { background: rgba(245,158,11,0.06) !important; }
.gap-detail-row { background: rgba(245,158,11,0.02) !important; }
.gap-detail-cell {
  padding: 0 !important;
  border-bottom: 2px solid var(--accent) !important;
}

/* Detail panel */
.gdp-panel { padding: 16px 20px 12px; }
.gdp-top-row {
  display: grid;
  grid-template-columns: 1fr 1fr;
  gap: 16px;
  margin-bottom: 14px;
}
.gdp-section { }
.gdp-section-title {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1.5px;
  color: var(--muted);
  margin-bottom: 8px;
  padding-bottom: 4px;
  border-bottom: 1px solid var(--border);
}
.gdp-summary-text {
  font-size: 11px;
  color: var(--text2);
  line-height: 1.7;
}
.gdp-watching { margin-bottom: 4px; }
.gdp-check-item {
  font-size: 10px;
  padding: 3px 0;
  line-height: 1.5;
}
.gdp-check-item.check-ok { color: #00c853; }
.gdp-check-item.check-no { color: var(--muted); }

/* Action guide 3 boxes */
.gdp-action-row { margin-bottom: 14px; }
.gdp-action-boxes {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 10px;
}
.gdp-action-box {
  border-radius: 6px;
  padding: 10px 12px;
}
.gdp-action-box.bullish {
  background: rgba(0,200,83,0.05);
  border: 1px solid rgba(0,200,83,0.25);
}
.gdp-action-box.bearish {
  background: rgba(255,23,68,0.05);
  border: 1px solid rgba(255,23,68,0.25);
}
.gdp-action-box.target {
  background: rgba(245,158,11,0.05);
  border: 1px solid rgba(245,158,11,0.25);
}
.gdp-box-title {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  margin-bottom: 6px;
}
.gdp-action-box.bullish .gdp-box-title { color: #00c853; }
.gdp-action-box.bearish .gdp-box-title { color: #ff1744; }
.gdp-action-box.target .gdp-box-title { color: #f59e0b; }
.gdp-box-text {
  font-size: 10px;
  color: var(--text2);
  line-height: 1.6;
}

/* Risk warnings */
.gdp-risk-row { }
.gdp-risk-box {
  background: rgba(255,23,68,0.03);
  border: 1px solid rgba(255,23,68,0.12);
  border-left: 3px solid rgba(255,23,68,0.4);
  border-radius: 6px;
  padding: 10px 14px;
  display: flex;
  flex-wrap: wrap;
  gap: 4px 24px;
  align-items: flex-start;
}
.gdp-risk-title {
  font-family: var(--font-mono);
  font-size: 9px;
  font-weight: 700;
  color: #ff1744;
  text-transform: uppercase;
  letter-spacing: 0.8px;
  width: 100%;
  margin-bottom: 6px;
}
.gdp-risk-item {
  font-size: 10px;
  color: var(--muted);
  line-height: 1.5;
  width: calc(50% - 12px);
}
.gdp-risk-item::before { content: '→ '; }

/* Action and signal badges */
.action-buy-badge {
  background: rgba(0,200,83,0.15);
  color: #00c853;
  border: 1px solid rgba(0,200,83,0.35);
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
  white-space: nowrap;
}
.action-watch-badge {
  background: rgba(245,158,11,0.15);
  color: #f59e0b;
  border: 1px solid rgba(245,158,11,0.35);
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
  white-space: nowrap;
}
.action-bounce-badge {
  background: rgba(6,182,212,0.15);
  color: #06b6d4;
  border: 1px solid rgba(6,182,212,0.35);
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
  white-space: nowrap;
}
.action-avoid-badge {
  background: rgba(100,116,139,0.1);
  color: var(--muted);
  border: 1px solid var(--border);
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
  white-space: nowrap;
}
.action-monitor-badge {
  background: rgba(139,92,246,0.1);
  color: #8b5cf6;
  border: 1px solid rgba(139,92,246,0.25);
  font-size: 9px;
  padding: 2px 7px;
  border-radius: 3px;
  font-family: var(--font-mono);
  font-weight: 700;
  white-space: nowrap;
}

/* Strategy guide section */
.gaps-guide-section {
  border: 1px solid var(--border);
  border-radius: 8px;
  margin-top: 20px;
  margin-bottom: 16px;
  overflow: hidden;
}
.gaps-guide-header {
  display: flex;
  justify-content: space-between;
  align-items: center;
  padding: 12px 16px;
  background: var(--surface2);
  cursor: pointer;
  font-family: var(--font-mono);
  font-size: 11px;
  font-weight: 700;
  color: var(--text2);
  letter-spacing: 0.3px;
  border-bottom: 1px solid var(--border);
  user-select: none;
}
.gaps-guide-header:hover { background: var(--surface3); }
#gaps-guide-body { padding: 16px; }

@media (max-width: 900px) {
  .gdp-top-row { grid-template-columns: 1fr; }
  .gdp-action-boxes { grid-template-columns: 1fr; }
  .gdp-risk-item { width: 100%; }
}

/* === CRITICAL FIX CSS === */

/* P1 offline banner — neutral (native mode, not an error) */
.p1-offline-banner {
  background: rgba(107,114,128,0.07);
  border: 1px solid rgba(107,114,128,0.2);
  border-left: 4px solid #6b7280;
  border-radius: 6px;
  padding: 10px 16px;
  margin-bottom: 12px;
  font-size: 11px;
  color: #9ca3af;
  display: flex;
  align-items: center;
  gap: 10px;
  line-height: 1.5;
}

/* Replaced signal card */
.sig-card.replaced {
  border-left: 3px solid #ff9100;
  opacity: 0.75;
  background: linear-gradient(to right, rgba(255,145,0,0.04) 0%, var(--surface) 40%);
}
.result-badge.replaced {
  background: rgba(255,145,0,0.12);
  color: #ff9100;
  border: 1px solid rgba(255,145,0,0.25);
}

/* Track position button */
.sig-track-row {
  margin-top: 8px;
  padding-top: 8px;
  border-top: 1px solid var(--border);
}
.sig-track-btn {
  background: rgba(245,158,11,0.08);
  color: #f59e0b;
  border: 1px solid rgba(245,158,11,0.25);
  border-radius: 5px;
  padding: 5px 12px;
  font-size: 10px;
  font-weight: 600;
  cursor: pointer;
  font-family: var(--font-mono);
  transition: all 0.15s;
  letter-spacing: 0.3px;
}
.sig-track-btn:hover {
  background: rgba(245,158,11,0.15);
  border-color: rgba(245,158,11,0.5);
}

/* P1 status nav pills */
.nav-pill.p1-live { background: rgba(0,200,83,0.15); color: #00c853; border-color: rgba(0,200,83,0.35); }
.nav-pill.p1-cached { background: rgba(255,145,0,0.15); color: #ff9100; border-color: rgba(255,145,0,0.35); }
.nav-pill.p1-offline { background: rgba(255,23,68,0.15); color: #ff1744; border-color: rgba(255,23,68,0.35); }

/* Positions tab */
.pos-stats-bar {
  display: grid;
  grid-template-columns: repeat(5, 1fr);
  gap: 8px;
  margin-bottom: 16px;
}
.pos-stat {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 8px;
  padding: 12px;
  text-align: center;
}
.pos-stat-num {
  display: block;
  font-family: var(--font-mono);
  font-size: 24px;
  font-weight: 700;
  line-height: 1;
  margin-bottom: 4px;
}
.pos-stat-lbl {
  font-size: 9px;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
}
.pos-grid {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 12px;
  margin-bottom: 16px;
}
.pos-card {
  padding: 14px 16px;
}
@media (max-width: 900px) {
  .pos-grid { grid-template-columns: 1fr; }
  .pos-stats-bar { grid-template-columns: repeat(3,1fr); }
}

/* ═══════════════════════════════════════════════════════════════
   TRADE LOG / PERSONAL JOURNAL
   ═══════════════════════════════════════════════════════════════ */

.account-cards-row {
  display: grid;
  grid-template-columns: repeat(3, 1fr);
  gap: 14px;
  margin-bottom: 20px;
}

.account-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
}
.account-card.live  { border-left: 4px solid #00c853; }
.account-card.prop  { border-left: 4px solid #3b82f6; }
.account-card.paper { border-left: 4px solid #8b5cf6; }

.ac-label {
  font-size: 10px;
  font-weight: 700;
  text-transform: uppercase;
  letter-spacing: 1px;
  color: var(--muted);
  margin-bottom: 8px;
}
.ac-balance {
  font-family: var(--font-mono);
  font-size: 22px;
  font-weight: 800;
  color: var(--text);
  margin-bottom: 4px;
}
.ac-pnl { font-family: var(--font-mono); font-size: 13px; margin-bottom: 10px; }
.ac-pnl.positive { color: #00c853; }
.ac-pnl.negative { color: #ff1744; }
.ac-pnl.flat     { color: var(--muted); }

.ac-rule-bar   { margin-bottom: 8px; }
.ac-rule-label {
  display: flex;
  justify-content: space-between;
  font-size: 9px;
  color: var(--muted);
  margin-bottom: 3px;
}
.ac-rule-track {
  height: 4px;
  background: var(--surface3);
  border-radius: 2px;
  overflow: hidden;
}
.ac-rule-fill { height: 100%; border-radius: 2px; transition: width 0.3s; }
.ac-rule-fill.safe    { background: #00c853; }
.ac-rule-fill.warning { background: #ff9100; }
.ac-rule-fill.danger  { background: #ff1744; animation: dangerPulse 1s ease infinite; }
@keyframes dangerPulse { 0%,100% { opacity:1; } 50% { opacity:0.5; } }

.quick-log-btn {
  width: 100%;
  padding: 14px;
  background: rgba(0,200,83,0.1);
  border: 2px dashed rgba(0,200,83,0.3);
  border-radius: 10px;
  color: #00c853;
  font-size: 14px;
  font-weight: 700;
  font-family: var(--font-mono);
  cursor: pointer;
  margin-bottom: 20px;
  transition: all 0.15s;
  letter-spacing: 1px;
}
.quick-log-btn:hover {
  background: rgba(0,200,83,0.15);
  border-color: rgba(0,200,83,0.5);
}

.psych-alert {
  border-radius: 8px;
  padding: 12px 16px;
  margin-bottom: 10px;
  font-size: 11px;
  border: 1px solid;
}
.psych-alert.warning {
  background: rgba(255,145,0,0.08);
  border-color: rgba(255,145,0,0.25);
  color: #ff9100;
}
.psych-alert.danger {
  background: rgba(255,23,68,0.08);
  border-color: rgba(255,23,68,0.25);
  color: #ff1744;
}
.psych-alert.insight {
  background: rgba(6,182,212,0.08);
  border-color: rgba(6,182,212,0.25);
  color: #06b6d4;
}

.trade-log-form {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 20px;
  margin-bottom: 20px;
}
.tlf-section {
  margin-bottom: 16px;
  padding-bottom: 16px;
  border-bottom: 1px solid var(--border);
}
.tlf-section:last-child { border-bottom: none; margin-bottom: 0; }
.tlf-section-title {
  font-size: 10px;
  font-weight: 700;
  color: var(--muted);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px;
}
.tlf-input {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 6px;
  padding: 8px 12px;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 12px;
  width: 100%;
  margin-bottom: 8px;
}
.tlf-input:focus { outline: none; border-color: var(--accent); }
.tlf-grid   { display: grid; grid-template-columns: 1fr 1fr; gap: 8px; }
.tlf-grid-4 { display: grid; grid-template-columns: repeat(4, 1fr); gap: 6px; }
.tlf-grid-3 { display: grid; grid-template-columns: repeat(3, 1fr); gap: 6px; }

.tlf-select {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 6px;
  padding: 8px 12px;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 12px;
  width: 100%;
  margin-bottom: 8px;
  cursor: pointer;
}
.tlf-textarea {
  background: var(--surface);
  border: 1px solid var(--border2);
  border-radius: 6px;
  padding: 8px 12px;
  color: var(--text);
  font-family: var(--font-mono);
  font-size: 12px;
  width: 100%;
  resize: vertical;
  min-height: 60px;
}
.tlf-textarea:focus { outline: none; border-color: var(--accent); }

.tlf-auto-field {
  position: relative;
}
.tlf-auto-badge {
  position: absolute;
  right: 8px;
  top: 50%;
  transform: translateY(-80%);
  font-size: 8px;
  color: var(--muted);
  background: var(--surface3);
  padding: 1px 5px;
  border-radius: 3px;
  font-family: var(--font-mono);
}

.psych-btn {
  padding: 6px 12px;
  border-radius: 20px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
  white-space: nowrap;
}
.psych-btn.selected             { background: rgba(245,158,11,0.15); color: #f59e0b; border-color: rgba(245,158,11,0.4); }
.psych-btn.calm.selected        { background: rgba(0,200,83,0.15); color: #00c853; border-color: rgba(0,200,83,0.35); }
.psych-btn.disciplined.selected { background: rgba(0,200,83,0.12); color: #00c853; border-color: rgba(0,200,83,0.3); }
.psych-btn.fearful.selected,
.psych-btn.anxious.selected     { background: rgba(255,23,68,0.15); color: #ff1744; border-color: rgba(255,23,68,0.35); }
.psych-btn.revenge.selected,
.psych-btn.fomo.selected        { background: rgba(255,23,68,0.12); color: #ff5252; border-color: rgba(255,23,68,0.3); }

.psych-btn-row { display: flex; flex-wrap: wrap; gap: 6px; margin-bottom: 8px; }

.dir-btn {
  padding: 8px 20px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 800;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.dir-btn.long.selected  { background: rgba(0,200,83,0.2); color: #00c853; border-color: #00c853; }
.dir-btn.short.selected { background: rgba(255,23,68,0.2); color: #ff1744; border-color: #ff1744; }

.acct-btn {
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.acct-btn.selected.live  { background: rgba(0,200,83,0.15); color: #00c853; border-color: #00c853; }
.acct-btn.selected.prop  { background: rgba(59,130,246,0.15); color: #3b82f6; border-color: #3b82f6; }
.acct-btn.selected.paper { background: rgba(139,92,246,0.15); color: #8b5cf6; border-color: #8b5cf6; }

.confidence-slider {
  width: 100%;
  accent-color: #f59e0b;
  margin: 8px 0;
}
.confidence-display {
  font-family: var(--font-mono);
  font-size: 18px;
  font-weight: 800;
  color: #f59e0b;
  text-align: center;
  margin-bottom: 4px;
}

.grade-btn {
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 13px;
  font-weight: 800;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.grade-btn.A.selected { background: rgba(0,200,83,0.2); color: #00c853; border-color: #00c853; }
.grade-btn.B.selected { background: rgba(6,182,212,0.2); color: #06b6d4; border-color: #06b6d4; }
.grade-btn.C.selected { background: rgba(245,158,11,0.2); color: #f59e0b; border-color: #f59e0b; }
.grade-btn.D.selected { background: rgba(255,145,0,0.2); color: #ff9100; border-color: #ff9100; }
.grade-btn.F.selected { background: rgba(255,23,68,0.2); color: #ff1744; border-color: #ff1744; }

.outcome-btn {
  padding: 6px 14px;
  border-radius: 6px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.outcome-btn.TP1.selected, .outcome-btn.TP2.selected { background: rgba(0,200,83,0.15); color: #00c853; border-color: #00c853; }
.outcome-btn.STOP.selected { background: rgba(255,23,68,0.15); color: #ff1744; border-color: #ff1744; }
.outcome-btn.MANUAL.selected, .outcome-btn.PROP_RULE.selected { background: rgba(245,158,11,0.15); color: #f59e0b; border-color: #f59e0b; }

.regret-btn {
  padding: 5px 11px;
  border-radius: 14px;
  font-size: 9px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.regret-btn.selected { background: rgba(255,145,0,0.15); color: #ff9100; border-color: #ff9100; }

.open-trades-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 11px;
}
.open-trades-table th {
  background: var(--surface3);
  color: var(--muted);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 8px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.open-trades-table td {
  padding: 8px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  color: var(--text2);
}
.open-trades-table tr:hover td { background: rgba(245,158,11,0.04); }

.prop-rules-panel {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  margin-top: 16px;
}
.prop-rule-item { margin-bottom: 14px; }
.prop-rule-header {
  display: flex;
  justify-content: space-between;
  font-size: 11px;
  margin-bottom: 4px;
}
.prop-rule-name  { color: var(--text2); font-weight: 600; }
.prop-rule-value { font-family: var(--font-mono); font-weight: 700; }
.prop-rule-value.safe    { color: #00c853; }
.prop-rule-value.warning { color: #ff9100; }
.prop-rule-value.danger  { color: #ff1744; }

.perf-win-bar {
  height: 20px;
  border-radius: 4px;
  background: var(--surface3);
  overflow: hidden;
  display: flex;
  margin: 8px 0;
}
.perf-win-fill  { background: #00c853; transition: width 0.4s; }
.perf-loss-fill { background: #ff1744; flex: 1; }

.perf-table {
  width: 100%;
  border-collapse: collapse;
  font-family: var(--font-mono);
  font-size: 11px;
}
.perf-table th {
  background: var(--surface3);
  color: var(--muted);
  font-size: 9px;
  text-transform: uppercase;
  letter-spacing: 1px;
  padding: 6px 10px;
  text-align: left;
  border-bottom: 1px solid var(--border);
}
.perf-table td {
  padding: 6px 10px;
  border-bottom: 1px solid rgba(255,255,255,0.03);
  color: var(--text2);
}

.risk-calc-display {
  background: var(--surface3);
  border-radius: 6px;
  padding: 10px 14px;
  font-family: var(--font-mono);
  font-size: 12px;
  margin-bottom: 8px;
  display: flex;
  gap: 20px;
}
.risk-calc-item span:first-child { color: var(--muted); font-size: 9px; display: block; }
.risk-calc-item span:last-child  { color: var(--text); font-weight: 700; }

.tj-perf-toggle {
  display: flex;
  gap: 6px;
  margin-bottom: 16px;
}
.tj-perf-btn {
  padding: 5px 14px;
  border-radius: 14px;
  font-size: 10px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.tj-perf-btn.active {
  background: rgba(245,158,11,0.15);
  color: var(--accent);
  border-color: rgba(245,158,11,0.4);
}

.weekly-review-card {
  background: var(--surface2);
  border: 1px solid var(--border);
  border-radius: 10px;
  padding: 16px;
  margin-bottom: 16px;
}
.weekly-review-title {
  font-size: 11px;
  font-weight: 700;
  color: var(--accent);
  font-family: var(--font-mono);
  text-transform: uppercase;
  letter-spacing: 1px;
  margin-bottom: 10px;
}

.tj-log-btn {
  padding: 10px 20px;
  border-radius: 6px;
  font-size: 12px;
  font-weight: 700;
  cursor: pointer;
  border: none;
  background: var(--accent);
  color: #000;
  font-family: var(--font-mono);
  transition: all 0.15s;
  letter-spacing: 0.5px;
}
.tj-log-btn:hover { background: var(--accent2); }

.tj-close-btn {
  padding: 8px 16px;
  border-radius: 6px;
  font-size: 11px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid rgba(0,200,83,0.3);
  background: rgba(0,200,83,0.08);
  color: #00c853;
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.tj-close-btn:hover { background: rgba(0,200,83,0.15); }

.tj-edit-btn {
  padding: 5px 10px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid var(--border2);
  background: var(--surface3);
  color: var(--muted);
  font-family: var(--font-mono);
  transition: all 0.15s;
}
.tj-edit-btn:hover { color: var(--accent); border-color: rgba(245,158,11,0.4); }

.signal-log-btn {
  padding: 4px 10px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  cursor: pointer;
  border: 1px solid rgba(245,158,11,0.25);
  background: rgba(245,158,11,0.06);
  color: var(--accent);
  font-family: var(--font-mono);
  transition: all 0.15s;
  white-space: nowrap;
}
.signal-log-btn:hover { background: rgba(245,158,11,0.12); }

/* === FIX 3: Screener progress bar === */
.scan-progress-bar {
  height: 3px;
  background: var(--surface3);
  border-radius: 2px;
  overflow: hidden;
  margin-top: 6px;
}
.scan-progress-fill {
  height: 100%;
  background: linear-gradient(to right, #00c853, #f59e0b);
  width: 0%;
  border-radius: 2px;
}
@keyframes scanProgress {
  from { width: 0%; }
  to { width: 100%; }
}

/* === FIX 4: Screener status badges === */
.ssb-badge {
  display: inline-block;
  padding: 2px 7px;
  border-radius: 4px;
  font-size: 9px;
  font-weight: 700;
  font-family: var(--font-mono);
  cursor: help;
  white-space: nowrap;
}
.ssb-badge-entry   { background: rgba(0,200,83,0.15); color: #00c853; border: 1px solid rgba(0,200,83,0.3); }
.ssb-badge-waiting { background: rgba(245,158,11,0.12); color: #f59e0b; border: 1px solid rgba(245,158,11,0.3); }
.ssb-badge-extended{ background: rgba(255,145,0,0.12); color: #ff9100; border: 1px solid rgba(255,145,0,0.3); }
.ssb-badge-chase   { background: rgba(255,23,68,0.12); color: #ff1744; border: 1px solid rgba(255,23,68,0.3); }

/* === FIX 5: Gap detail no overflow === */
.gdp-panel {
  padding: 16px 20px 12px;
  overflow-x: hidden;
  max-width: 100%;
}
.gdp-action-boxes {
  display: grid;
  grid-template-columns: 1fr;
  gap: 10px;
}
@media (min-width: 1100px) {
  .gdp-action-boxes { grid-template-columns: repeat(3, 1fr); }
}

/* ── Mobile navigation ──────────────────────────────────────────────────────── */
@media (max-width: 768px) {
  .topbar {
    flex-wrap: wrap;
    height: auto;
    padding: 8px;
  }

  .topbar-tabs {
    width: 100%;
    overflow-x: auto;
    -webkit-overflow-scrolling: touch;
    scrollbar-width: none;
    display: flex;
    flex-wrap: nowrap;
    gap: 0;
    border-top: 1px solid var(--border);
    margin-top: 6px;
    padding-top: 4px;
  }

  .nav-tab {
    padding: 8px 12px;
    font-size: 11px;
    white-space: nowrap;
    min-height: 36px;
    display: flex;
    align-items: center;
  }

  .topbar-right {
    display: none;
  }

  .brand-sub {
    display: none;
  }

  .page-body {
    padding: 10px;
  }

  [id^="sec-"] { padding: 10px; }

  /* Mobile typography & tap targets */
  body { font-size: 13px; }
  td, th { font-size: 11px; }
  code, pre { font-size: 11px; }
  button, .btn, .refresh-btn { min-height: 40px; }
  .nav-tab { min-height: 36px; }

}

/* ── More dropdown (position:fixed escapes overflow-x:auto clip on .topbar-tabs) */
#more-dd { display: none; position: fixed; top: var(--nav-height, 44px); right: 0; z-index: 9999; }
#more-dd.open { display: block; }
#more-overlay { display: none; position: fixed; inset: 0; z-index: 9998; }
#more-overlay.open { display: block; }
