/* ==========================================
   dashboard.css — Symbol dashboard engine (Growth / Valuation tabs,
   future full-page). Self-contained: relies only on CSS vars the rest
   of the app already exposes (--card-bg, --text-primary, etc.).
   ========================================== */

.dash-shell {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}

/* ── Dashboard tab outer shell (single modal tab hosting many views) ── */
.dash-modal-shell {
  display: flex;
  flex-direction: column;
  gap: 12px;
  width: 100%;
}
.dash-view-switcher {
  display: inline-flex;
  flex-wrap: wrap;
  gap: 4px;
  padding: 4px;
  background: var(--card-bg-2, rgba(255, 255, 255, 0.04));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  border-radius: 8px;
  align-self: flex-start;
}
.dash-view-btn {
  background: transparent;
  color: var(--text-secondary, #969dad);
  border: none;
  padding: 6px 14px;
  font-size: 12px;
  font-weight: 600;
  border-radius: 5px;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.dash-view-btn:hover { color: var(--text-primary, #e6e8ee); background: rgba(58, 124, 238, 0.08); }
.dash-view-btn.active { background: #3a7cee; color: #fff; }
.dash-view-mount { width: 100%; }

/* ── Timeframe toolbar ── */
.dash-toolbar {
  display: flex;
  align-items: center;
  justify-content: flex-start;
  padding: 4px 0 8px;
  border-bottom: 1px solid var(--border, rgba(255, 255, 255, 0.06));
}
.dash-tf-row {
  display: flex;
  gap: 14px;
  flex-wrap: wrap;
}
.dash-tf-group {
  display: inline-flex;
  background: var(--card-bg-2, rgba(255, 255, 255, 0.04));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  border-radius: 6px;
  overflow: hidden;
}
.dash-tf-btn {
  background: transparent;
  color: var(--text-secondary, #969dad);
  border: none;
  padding: 5px 10px;
  font-size: 11px;
  font-weight: 600;
  cursor: pointer;
  transition: background 0.15s, color 0.15s;
}
.dash-tf-btn:hover { color: var(--text-primary, #e6e8ee); background: rgba(58, 124, 238, 0.08); }
.dash-tf-btn.active { background: #3a7cee; color: #fff; }

/* ── Grid layout ── */
.dash-grid {
  display: grid;
  grid-template-columns: 1fr;
  gap: 14px;
  width: 100%;
}
@media (min-width: 900px) {
  .dash-grid { grid-template-columns: repeat(2, minmax(0, 1fr)); }
  .dash-grid .dash-slot-stat-box { grid-column: 1 / -1; }
}

.dash-slot {
  min-width: 0;
}

/* ── Stat-box row ── */
.dash-stat-row {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(140px, 1fr));
  gap: 10px;
}
.dash-stat {
  background: var(--card-bg-2, rgba(255, 255, 255, 0.04));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  border-radius: 8px;
  padding: 10px 12px;
  min-width: 0;
}
.dash-stat-label {
  font-size: 10px;
  text-transform: uppercase;
  letter-spacing: 0.6px;
  color: var(--text-secondary, #969dad);
  margin-bottom: 4px;
}
.dash-stat-value {
  font-size: 18px;
  font-weight: 700;
  color: var(--text-primary, #e6e8ee);
  line-height: 1.2;
}
.dash-stat-asof {
  margin-top: 2px;
  font-size: 10px;
  color: var(--text-secondary, #969dad);
}

/* ── Chart widget ── */
.dash-widget {
  background: var(--card-bg-2, rgba(255, 255, 255, 0.02));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  border-radius: 8px;
  padding: 10px 12px 12px;
}
.dash-widget-head {
  display: flex;
  justify-content: space-between;
  align-items: baseline;
  gap: 10px;
  margin-bottom: 6px;
  flex-wrap: wrap;
}
.dash-widget-title {
  font-size: 13px;
  font-weight: 700;
  color: var(--text-primary, #e6e8ee);
}
.dash-widget-currents {
  display: inline-flex;
  gap: 10px;
  flex-wrap: wrap;
  font-size: 11px;
  color: var(--text-secondary, #969dad);
}
.dash-widget-curr strong {
  color: var(--text-primary, #e6e8ee);
  font-weight: 600;
}
.dash-widget-note {
  margin: 4px 0 8px;
  font-size: 11px;
  color: var(--text-secondary, #969dad);
  font-style: italic;
}
.dash-widget-chart {
  width: 100%;
  min-height: 240px;
  position: relative;
}

/* ── States ── */
.dash-loading,
.dash-empty,
.dash-error {
  padding: 24px 12px;
  text-align: center;
  color: var(--text-secondary, #969dad);
  font-size: 13px;
}
.dash-error { color: #e74c3c; }

/* ════════════════════════════════════════════
   Full-page multi-symbol dashboard (Feature 2)
   ════════════════════════════════════════════ */
.dash-page-root { padding: 16px; }
.dash-page { display: flex; flex-direction: column; gap: 16px; }
.dash-page-toolbar {
  display: flex; flex-direction: column; gap: 12px;
  background: var(--card-bg-2, rgba(255, 255, 255, 0.03));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  border-radius: 8px;
  padding: 12px 14px;
}
.dash-page-row {
  display: flex; flex-wrap: wrap; gap: 16px; align-items: flex-end;
}
.dash-page-section { display: flex; flex-direction: column; gap: 6px; min-width: 0; }
.dash-page-section-grow { flex: 1 1 320px; }
.dash-page-label {
  font-size: 10px; text-transform: uppercase; letter-spacing: 0.6px;
  color: var(--text-secondary, #969dad); font-weight: 600;
}

/* ── Symbol selector ── */
.dash-symbol-selector { display: flex; gap: 10px; flex-wrap: wrap; align-items: center; min-height: 32px; }
.dash-sym-chips { display: inline-flex; gap: 6px; flex-wrap: wrap; }
.dash-sym-chip {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: 14px;
  border: 1.5px solid #3a7cee;
  background: rgba(58, 124, 238, 0.08);
  color: var(--text-primary, #e6e8ee);
  font-size: 12px; font-weight: 600;
}
.dash-sym-chip-x {
  background: transparent; border: none; color: var(--text-secondary, #969dad);
  cursor: pointer; padding: 0 2px; font-size: 14px; line-height: 1;
}
.dash-sym-chip-x:hover { color: #e74c3c; }
.dash-sym-empty { font-size: 12px; color: var(--text-secondary, #969dad); font-style: italic; }
.dash-sym-search { position: relative; min-width: 180px; }
.dash-sym-input {
  width: 100%; padding: 6px 10px;
  background: var(--card-bg, #1a1f2c); color: var(--text-primary, #e6e8ee);
  border: 1px solid var(--border, rgba(255, 255, 255, 0.1));
  border-radius: 6px; font-size: 12px;
}
.dash-sym-suggest {
  position: absolute; top: calc(100% + 4px); left: 0; right: 0;
  background: var(--card-bg, #1a1f2c);
  border: 1px solid var(--border, rgba(255, 255, 255, 0.1));
  border-radius: 6px; max-height: 240px; overflow-y: auto;
  z-index: 50; box-shadow: 0 6px 24px rgba(0, 0, 0, 0.4);
}
.dash-sym-suggest:empty { display: none; }
.dash-sym-sug {
  padding: 8px 10px; cursor: pointer; font-size: 12px;
  display: flex; gap: 8px; align-items: baseline;
}
.dash-sym-sug:hover { background: rgba(58, 124, 238, 0.12); }
.dash-sym-sug-name { color: var(--text-secondary, #969dad); font-size: 11px; }

/* ── Saved views ── */
.dash-saved-views { display: inline-flex; gap: 6px; align-items: center; }
.dash-saved-select {
  background: var(--card-bg, #1a1f2c); color: var(--text-primary, #e6e8ee);
  border: 1px solid var(--border, rgba(255, 255, 255, 0.1));
  border-radius: 6px; padding: 6px 10px; font-size: 12px; min-width: 160px;
}
.dash-saved-btn {
  background: var(--card-bg-2, rgba(255, 255, 255, 0.04));
  color: var(--text-secondary, #969dad);
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  border-radius: 6px; padding: 6px 12px; font-size: 12px; font-weight: 600; cursor: pointer;
}
.dash-saved-btn:hover:not(:disabled) { color: var(--text-primary, #e6e8ee); background: rgba(58, 124, 238, 0.08); }
.dash-saved-btn:disabled { opacity: 0.4; cursor: not-allowed; }

/* ── Legend dot used in widget headers / comparison rows ── */
.dash-legend-dot {
  display: inline-block; width: 8px; height: 8px;
  border-radius: 50%; margin-right: 4px; vertical-align: middle;
}

/* ── Layout modes ── */
.dash-grid-overlay { grid-template-columns: 1fr; }
@media (min-width: 900px) { .dash-grid-overlay { grid-template-columns: repeat(2, minmax(0, 1fr)); } }
.dash-grid-multi   { grid-template-columns: 1fr; }
.dash-grid-grid    { grid-template-columns: 1fr; }
@media (min-width: 1200px) { .dash-grid-grid { grid-template-columns: repeat(3, minmax(0, 1fr)); } }

/* ── Small-multiple (side-by-side) ── */
.dash-sm-grid {
  display: grid; gap: 10px; width: 100%; align-items: stretch;
}
.dash-sm-col {
  background: var(--card-bg, rgba(0, 0, 0, 0.15));
  border: 1px solid var(--border, rgba(255, 255, 255, 0.06));
  border-radius: 6px; padding: 8px;
  min-width: 0;
}
.dash-sm-col-title {
  font-size: 12px; font-weight: 700; padding: 4px 6px 8px;
  color: var(--text-primary, #e6e8ee);
}

/* ── Comparison stat-row table ── */
.dash-cmp-wrap { overflow-x: auto; }
.dash-cmp-table {
  width: 100%; border-collapse: collapse; font-size: 12px;
}
.dash-cmp-table th, .dash-cmp-table td {
  padding: 6px 10px; text-align: right;
  border-bottom: 1px solid var(--border, rgba(255, 255, 255, 0.06));
}
.dash-cmp-table th.dash-cmp-sym {
  font-weight: 700; color: var(--text-primary, #e6e8ee);
  text-align: right;
}
.dash-cmp-table td.dash-cmp-label {
  text-align: left; color: var(--text-secondary, #969dad);
  font-weight: 600; font-size: 11px; text-transform: uppercase; letter-spacing: 0.4px;
}
.dash-cmp-table td.dash-cmp-val { font-weight: 600; }

/* ════════════════════════════════════════════
   Help modal + info-button affordance
   ════════════════════════════════════════════ */
.dash-info-btn {
  display: inline-flex; align-items: center; justify-content: center;
  background: transparent; border: none; padding: 0; margin-left: 4px;
  color: var(--text-secondary, #969dad); cursor: pointer; vertical-align: middle;
  border-radius: 50%; width: 18px; height: 18px;
  transition: color 0.15s, background 0.15s;
}
.dash-info-btn .material-symbols-outlined {
  font-size: 16px; line-height: 1; font-variation-settings: 'wght' 500;
}
.dash-info-btn:hover { color: #3a7cee; background: rgba(58, 124, 238, 0.12); }
.dash-info-inline {
  margin-left: 4px; opacity: 0.55;
}
.dash-info-inline:hover { opacity: 1; }

.dash-help-overlay {
  position: fixed; inset: 0;
  background: rgba(0, 0, 0, 0.55);
  display: none; align-items: center; justify-content: center;
  z-index: 9999; padding: 24px;
}
.dash-help-overlay.visible { display: flex; }
.dash-help-modal {
  background: var(--card-bg, #1a1f2c);
  color: var(--text-primary, #e6e8ee);
  border: 1px solid var(--border, rgba(255, 255, 255, 0.1));
  border-radius: 10px;
  max-width: 640px; width: 100%; max-height: 80vh; overflow-y: auto;
  box-shadow: 0 12px 48px rgba(0, 0, 0, 0.45);
}
.dash-help-head {
  display: flex; justify-content: space-between; align-items: center;
  padding: 14px 18px; border-bottom: 1px solid var(--border, rgba(255, 255, 255, 0.06));
}
.dash-help-title { font-size: 15px; font-weight: 700; }
.dash-help-close {
  background: transparent; border: none; color: var(--text-secondary, #969dad);
  font-size: 24px; line-height: 1; cursor: pointer; padding: 0 4px;
}
.dash-help-close:hover { color: var(--text-primary, #e6e8ee); }
.dash-help-body { padding: 14px 18px; }
.dash-help-section + .dash-help-section {
  margin-top: 16px; padding-top: 16px;
  border-top: 1px dashed var(--border, rgba(255, 255, 255, 0.08));
}
.dash-help-mname {
  font-size: 13px; font-weight: 700; margin: 0 0 8px;
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
}
.dash-help-desc {
  font-size: 12.5px; line-height: 1.55; color: var(--text-primary, #e6e8ee); margin-bottom: 8px;
}
.dash-help-interp {
  font-size: 12.5px; line-height: 1.55; color: var(--text-secondary, #c5c9d1);
  background: rgba(255, 255, 255, 0.03);
  border-left: 3px solid #3a7cee; border-radius: 4px;
  padding: 8px 10px;
}
.dash-help-interp-label {
  font-weight: 700; text-transform: uppercase; letter-spacing: 0.6px;
  font-size: 10px; color: #3a7cee; margin-right: 6px;
}
.dash-help-dir {
  font-size: 10px; font-weight: 700;
  padding: 2px 8px; border-radius: 10px;
  text-transform: uppercase; letter-spacing: 0.4px;
}
.dash-help-dir-up   { background: rgba(30, 203, 133, 0.15); color: #1ecb85; border: 1px solid rgba(30, 203, 133, 0.4); }
.dash-help-dir-down { background: rgba(231, 76, 60, 0.15);  color: #e74c3c; border: 1px solid rgba(231, 76, 60, 0.4); }
.dash-help-dir-ctx  { background: rgba(245, 166, 35, 0.15); color: #f5a623; border: 1px solid rgba(245, 166, 35, 0.4); }
.dash-help-empty { font-size: 12px; color: var(--text-secondary, #969dad); font-style: italic; }

/* ─── Forecast (CP5) ──────────────────────────────────────
   Card grid for the per-row signals plus the S/R and Risk panels.
   Uses the dash-widget container — same look as dashboard widgets —
   then layers signal chips, layouts, and a slim risk-bar on top. */
.tc-grid {
  display: grid;
  grid-template-columns: repeat(auto-fit, minmax(260px, 1fr));
  gap: 12px;
}
.tc-grid-wide {
  grid-template-columns: repeat(auto-fit, minmax(360px, 1fr));
}
.tc-row { padding: 12px 14px; }
.tc-row-head {
  display: flex; align-items: center; justify-content: space-between;
  margin-bottom: 10px;
}
.tc-row-title {
  display: flex; align-items: center; gap: 6px;
  font-size: 13px; font-weight: 600;
  color: var(--text-primary);
}
.tc-row-icon {
  font-size: 18px;
  color: var(--text-secondary, #969dad);
}
.tc-row-body { display: flex; align-items: center; gap: 10px; flex-wrap: wrap; }
.tc-row-notes {
  font-size: 13px;
  color: var(--text-primary);
}
.tc-row-reason {
  font-size: 11px;
  color: var(--text-secondary, #969dad);
  font-style: italic;
  margin-top: 4px;
}
/* Swing-structure chips on the Trend card (HH/HL/LH/LL) */
.tc-struct-row {
  display: flex; align-items: center; gap: 6px;
  margin-top: 6px;
}
.tc-struct-chip {
  font-size: 11px; font-weight: 700; letter-spacing: 0.3px;
  padding: 1px 6px; border-radius: 6px;
  background: rgba(150, 157, 173, 0.12);
  color: var(--text-secondary, #969dad);
  border: 1px solid rgba(150, 157, 173, 0.25);
}
.tc-struct-chip.pos { background: rgba(30, 203, 133, 0.14); color: #1ecb85; border-color: rgba(30, 203, 133, 0.4); }
.tc-struct-chip.neg { background: rgba(231, 76, 60, 0.14); color: #e74c3c; border-color: rgba(231, 76, 60, 0.4); }
.tc-struct-trend {
  font-size: 11px; color: var(--text-secondary, #969dad);
  text-transform: capitalize;
}
.tc-signal-badge {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 4px 10px; border-radius: 12px;
  font-size: 12px; font-weight: 600;
  background: rgba(150, 157, 173, 0.10);
  color: var(--text-secondary, #969dad);
  border: 1px solid rgba(150, 157, 173, 0.2);
}
.tc-signal-badge .material-symbols-outlined { font-size: 14px; }
.tc-signal-badge.pos {
  background: rgba(30, 203, 133, 0.12);
  color: #1ecb85;
  border-color: rgba(30, 203, 133, 0.35);
}
.tc-signal-badge.neg {
  background: rgba(231, 76, 60, 0.12);
  color: #e74c3c;
  border-color: rgba(231, 76, 60, 0.35);
}
.tc-signal-badge.tc-na {
  opacity: 0.6;
}
.tc-na { opacity: 0.7; }

/* Subtle left-edge accent so a row's signal reads at a glance even when the
   colored chip is off-screen on narrow widths. */
.tc-row.tc-row-bullish { box-shadow: inset 3px 0 0 0 #1ecb85; }
.tc-row.tc-row-bearish { box-shadow: inset 3px 0 0 0 #e74c3c; }
.tc-row.tc-row-neutral { box-shadow: inset 3px 0 0 0 rgba(150, 157, 173, 0.4); }
.tc-row.tc-row-na      { box-shadow: inset 3px 0 0 0 rgba(150, 157, 173, 0.2); }

/* ─── Verdict card ─── */
.tc-verdict { padding: 16px; margin-bottom: 16px; }
.tc-verdict-row {
  display: flex; align-items: center; justify-content: space-between;
  flex-wrap: wrap; gap: 12px;
}
.tc-verdict-label {
  font-size: 11px;
  color: var(--text-secondary, #969dad);
  text-transform: uppercase;
  letter-spacing: 0.5px;
  font-weight: 600;
}
.tc-verdict-band { font-size: 28px; font-weight: 700; }
.tc-verdict-stats {
  display: flex; gap: 24px; align-items: center;
}
.tc-verdict-score { font-size: 28px; font-weight: 600; color: var(--text-primary); }
.tc-verdict-bulls, .tc-verdict-bears { font-size: 20px; font-weight: 600; }

/* ─── Support / Resistance / Fib ─── */
.tc-sr { padding: 12px 14px; }
.tc-sr-body {
  display: grid;
  grid-template-columns: 1fr 1fr auto;
  gap: 16px;
  align-items: start;
}
@media (max-width: 640px) {
  .tc-sr-body { grid-template-columns: 1fr 1fr; }
  .tc-fib { grid-column: 1 / -1; }
}
.tc-sr-col-title {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--text-secondary, #969dad);
  margin-bottom: 6px;
  font-weight: 600;
}
.tc-level {
  font-size: 13px;
  padding: 4px 0;
  color: var(--text-primary);
}
.tc-level.pos { color: #1ecb85; }
.tc-level.neg { color: #e74c3c; }
.tc-level-meta {
  color: var(--text-secondary, #969dad);
  font-size: 11px;
  margin-left: 4px;
}
.tc-fib {
  padding-left: 16px;
  border-left: 1px solid var(--border, rgba(255,255,255,0.08));
}
.tc-fib-label {
  font-size: 11px;
  text-transform: uppercase;
  letter-spacing: 0.4px;
  color: var(--text-secondary, #969dad);
  margin-bottom: 6px;
  font-weight: 600;
}
.tc-fib-row {
  display: flex; justify-content: space-between; gap: 12px;
  font-size: 12px;
  color: var(--text-primary);
  padding: 2px 0;
}
.tc-fib-pct {
  color: var(--text-secondary, #969dad);
  min-width: 40px;
}

/* ─── Risk plan ─── */
.tc-risk { padding: 12px 14px; }
.tc-risk-grid {
  display: grid;
  grid-template-columns: repeat(4, 1fr);
  gap: 12px;
  margin-bottom: 10px;
}
.tc-risk-cell { min-width: 0; }
.tc-risk-label {
  font-size: 11px;
  color: var(--text-secondary, #969dad);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  font-weight: 600;
  margin-bottom: 4px;
}
.tc-risk-source {
  text-transform: none;
  font-weight: 400;
  letter-spacing: 0;
  opacity: 0.7;
}
.tc-risk-value {
  font-size: 16px;
  font-weight: 600;
  color: var(--text-primary);
}
.tc-risk-bar {
  display: flex;
  height: 6px;
  border-radius: 3px;
  overflow: hidden;
  background: rgba(150, 157, 173, 0.15);
}
.tc-risk-bar-risk    { flex: 1; background: #e74c3c; }
.tc-risk-bar-reward  { background: #1ecb85; }

/* Empty / placeholder row in the grid. */
.tc-empty-row {
  grid-column: 1 / -1;
  padding: 24px;
  text-align: center;
  color: var(--text-secondary, #969dad);
  font-style: italic;
}

/* ─── AI Thesis card ─── */
.tc-thesis { padding: 12px 14px; }
.tc-thesis-conf {
  font-size: 11px;
  color: var(--text-secondary, #969dad);
  margin-left: 8px;
  padding: 1px 8px;
  border-radius: 10px;
  background: rgba(58, 124, 238, 0.10);
  border: 1px solid rgba(58, 124, 238, 0.30);
  font-weight: 500;
  text-transform: none;
  letter-spacing: 0;
}
.tc-thesis-body {
  font-size: 14px;
  line-height: 1.5;
  color: var(--text-primary);
}
.tc-thesis-risks {
  margin-top: 10px;
  padding-top: 10px;
  border-top: 1px solid var(--border, rgba(255,255,255,0.08));
}
.tc-thesis-risks-label {
  font-size: 11px;
  color: var(--text-secondary, #969dad);
  text-transform: uppercase;
  letter-spacing: 0.4px;
  font-weight: 600;
  margin-bottom: 6px;
}
.tc-thesis-risk {
  font-size: 12px;
  color: var(--text-primary);
  padding: 2px 0;
}
.tc-thesis-err .tc-thesis-body {
  font-size: 13px;
  font-style: italic;
}

/* ─── History strip ─── */
.tc-history { padding: 10px 12px; }
.tc-hist-scroll {
  display: flex;
  gap: 8px;
  overflow-x: auto;
  padding-bottom: 4px;
}
.tc-hist-chip {
  flex: 0 0 auto;
  display: inline-flex;
  flex-direction: column;
  align-items: flex-start;
  gap: 2px;
  padding: 6px 10px;
  border-radius: 6px;
  border: 1px solid var(--border, rgba(255,255,255,0.08));
  background: transparent;
  cursor: pointer;
  font-family: inherit;
  font-size: 11px;
  color: var(--text-secondary, #969dad);
  text-align: left;
  transition: background 0.15s ease;
}
.tc-hist-chip:hover {
  background: rgba(150, 157, 173, 0.08);
}
.tc-hist-chip.tc-hist-active {
  border-color: var(--primary, #3a7cee);
  background: rgba(58, 124, 238, 0.08);
}
.tc-hist-time { font-size: 10px; opacity: 0.75; white-space: nowrap; }
.tc-hist-score { font-size: 14px; font-weight: 700; }
.tc-hist-verdict { font-size: 11px; font-weight: 500; }

/* Past-run banner */
.tc-past-banner {
  display: flex;
  align-items: center;
  gap: 8px;
  padding: 8px 12px;
  margin-bottom: 12px;
  border-radius: 6px;
  background: rgba(245, 166, 35, 0.10);
  border: 1px solid rgba(245, 166, 35, 0.30);
  color: var(--text-primary);
  font-size: 13px;
}
.tc-past-banner-btn {
  margin-left: auto;
  padding: 4px 10px;
  font-size: 12px;
  border-radius: 4px;
  border: 1px solid var(--border, rgba(255,255,255,0.15));
  background: transparent;
  cursor: pointer;
  color: var(--text-primary);
  font-family: inherit;
}
.tc-past-banner-btn:hover {
  background: rgba(255, 255, 255, 0.05);
}
