/* ============================================================================
   signals.css — MyLiveSignals card styling for finscans.com
   ----------------------------------------------------------------------------
   ADDITIVE. Loaded AFTER main.css, only on pages that render signal cards.
   Uses finscans design tokens exclusively (--bullish, --bearish, --neutral,
   --accent, --bg-card, --bg-subtle, --text*, --radius*, --shadow*). It never
   redefines :root, so finscans' light/dark theming stays intact and the signal
   card sits visually next to the news cards in the same grid.

   Reused finscans classes: .article-card, .card-accent-bar, .card-header,
   .card-body, .card-footer, .card-read-more.  Signal-specific additions below.
   ============================================================================ */

/* Type label that distinguishes a signal card from a news card --------------- */
.card-type-badge {
  font-size: 0.62rem; font-weight: 800; letter-spacing: 0.06em;
  text-transform: uppercase; padding: 3px 9px;
  border-radius: var(--radius-pill);
  background: var(--accent); color: #fff;
  flex-shrink: 0;
}

/* Accent bar tinted by signal direction (reuses .card-accent-bar base) -------- */
.card-accent-bar.signal-accent--bullish { background: var(--bullish); }
.card-accent-bar.signal-accent--bearish { background: var(--bearish); }
.card-accent-bar.signal-accent--neutral { background: var(--neutral); }

/* Header: type badge · pair/tf/dir · verdict --------------------------------- */
.signal-card__header { display: flex; align-items: center; gap: 8px; flex-wrap: wrap; }

.signal-pair { font-weight: 700; font-size: 0.95rem; }
.signal-pair a { color: var(--text); text-decoration: none; }
.signal-pair a:hover { color: var(--accent); }
.signal-dir { font-weight: 800; }
.signal-dir--bullish { color: var(--bullish); }
.signal-dir--bearish { color: var(--bearish); }

.signal-verdict { margin-left: auto; text-align: right; line-height: 1.05; }
.verdict-pct { font-size: 1.25rem; font-weight: 800; }
.verdict-pct--bullish { color: var(--bullish); }
.verdict-pct--bearish { color: var(--bearish); }
.verdict-strength {
  display: block; font-size: 0.58rem; font-weight: 700;
  color: var(--text-light); letter-spacing: 0.04em;
}

/* Probability bar (bullish vs bearish share) --------------------------------- */
.verdict-bar {
  display: flex; height: 6px; margin: 2px 0 6px;
  border-radius: var(--radius-pill); overflow: hidden;
  background: var(--bg-subtle);
}
.verdict-bar__bull { background: var(--bullish); }
.verdict-bar__bear { background: var(--bearish); }
.verdict-legend {
  display: flex; justify-content: space-between;
  font-size: 0.7rem; font-weight: 700; margin-bottom: 8px;
}
.verdict-legend .vl-bull { color: var(--bullish); }
.verdict-legend .vl-bear { color: var(--bearish); }

/* Pills row: new/updated · trading style · premium · forecast ---------------- */
.signal-pills { display: flex; flex-wrap: wrap; gap: 6px; margin: 8px 0; }
.signal-pills > span {
  font-size: 0.7rem; font-weight: 700; padding: 3px 9px; line-height: 1;
  border-radius: var(--radius-pill);
}
.card-badge--new      { background: var(--accent-glow); color: var(--accent); }
.card-badge--updated  { background: var(--bg-subtle);   color: var(--text-muted); }
.card-style           { background: var(--accent-glow); color: var(--accent); }
.card-forecast        { background: var(--bullish-bg);  color: var(--bullish-fg); }
.card-tier-premium    { background: rgba(245,196,81,0.16); color: #9a7b1f; }
[data-theme="dark"] .card-tier-premium { color: #f5c451; }

/* Signal-type chips ---------------------------------------------------------- */
.signal-types { display: flex; flex-wrap: wrap; gap: 5px; margin: 6px 0 2px; }
.signal-type-chip {
  font-size: 0.65rem; padding: 2px 7px; border-radius: var(--radius-sm);
  background: var(--bg-subtle); color: var(--text-muted);
}

/* MTF trend strip (8 timeframes) — shared with detail page later ------------- */
.mtf-strip { display: flex; gap: 4px; margin-top: 10px; }
.mtf-cell {
  flex: 1; display: flex; flex-direction: column; align-items: center; gap: 3px;
}
.mtf-bar {
  width: 100%; height: 18px; border-radius: 3px;
  background: var(--neutral);   /* base; render_mtf_strip sets inline opacity 0.25–1.0 */
}
.mtf-bar--bull { background: var(--bullish); }
.mtf-bar--bear { background: var(--bearish); }
.mtf-bar--flat { background: var(--text-light); }
.mtf-tf {
  font-size: 0.6rem; font-weight: 700; letter-spacing: 0.02em;
  color: var(--text-light);
}

/* Footer: candle time + relative · view link -------------------------------- */
.signal-card__footer {
  display: flex; align-items: center; justify-content: space-between; gap: 8px;
}
.signal-time { font-size: 0.7rem; color: var(--text-light); }
.signal-time .time-ago { white-space: nowrap; }

/* ============================================================================
   Signal detail page (.signal-detail)
   ============================================================================ */
.signal-detail { max-width: 880px; margin: 0 auto; padding: 24px 16px 56px; }

.sd-breadcrumb { font-size: 0.8rem; margin-bottom: 16px; }
.sd-breadcrumb a { color: var(--text-muted); text-decoration: none; }
.sd-breadcrumb a:hover { color: var(--accent); }

.sd-card {
  background: var(--bg-card); border: 1px solid var(--border);
  border-radius: var(--radius); box-shadow: var(--shadow-sm);
  padding: 22px 24px; margin-bottom: 18px;
}

.sd-head { display: flex; align-items: flex-start; gap: 14px; flex-wrap: wrap; }
.sd-head__main { flex: 1 1 auto; min-width: 0; }
.sd-pair { font-size: 1.5rem; font-weight: 800; line-height: 1.15; }
.sd-pair .signal-dir--bullish { color: var(--bullish); }
.sd-pair .signal-dir--bearish { color: var(--bearish); }
.sd-sub { font-size: 0.82rem; color: var(--text-muted); margin-top: 4px; }

.sd-verdict { text-align: right; line-height: 1.05; flex-shrink: 0; }
.sd-verdict .verdict-pct { font-size: 2.1rem; font-weight: 800; }
.sd-verdict .verdict-strength { font-size: 0.65rem; }

.sd-section { margin-top: 18px; }
.sd-section__title {
  font-size: 0.72rem; font-weight: 800; text-transform: uppercase;
  letter-spacing: 0.06em; color: var(--text-light); margin-bottom: 10px;
}

/* MTF strip on detail: taller bars */
.signal-detail .mtf-bar { height: 40px; }

/* Support / resistance */
.sd-sr { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; }
.sd-sr-col__label { font-size: 0.72rem; font-weight: 700; margin-bottom: 6px; }
.sd-sr-col--res .sd-sr-col__label { color: var(--bearish); }
.sd-sr-col--sup .sd-sr-col__label { color: var(--bullish); }
.sd-level {
  font-size: 0.85rem; font-variant-numeric: tabular-nums;
  padding: 4px 0; border-bottom: 1px solid var(--border); color: var(--text);
}
.sd-level:last-child { border-bottom: 0; }

/* Fired-signal list */
.sd-types { display: flex; flex-wrap: wrap; gap: 6px; }
.sd-types .signal-type-chip { font-size: 0.72rem; }

/* AI commentary */
.sd-ai { font-size: 0.92rem; line-height: 1.6; color: var(--text); }

/* finscans cross-link CTA (Phase-2 bridge: signal → asset/news) */
.sd-bridge {
  display: flex; align-items: center; gap: 10px; flex-wrap: wrap;
  background: var(--bg-subtle); border: 1px solid var(--border);
  border-radius: var(--radius-sm); padding: 12px 16px; margin-top: 18px;
}
.sd-bridge a {
  font-size: 0.82rem; font-weight: 700; color: var(--accent);
  text-decoration: none; white-space: nowrap;
}
.sd-bridge a:hover { text-decoration: underline; }