/* =========================================================================
   Money Racket — bespoke Apple-HIG design layer.
   Scoped entirely under [data-niche="moneyracket"] so Inside businesses is untouched.
   Loaded AFTER global.css, only for the moneyracket build.
   Goal: depth, rhythm, restraint, and data-viz that reads "premium", not "AI dump".
   ========================================================================= */

[data-niche="moneyracket"] {
  --radius: 16px;
  --radius-sm: 12px;
  --radius-lg: 20px;
  --shadow-xs: 0 1px 2px rgba(19, 37, 27, .05);
  --shadow-sm: 0 1px 2px rgba(19, 37, 27, .04), 0 2px 6px rgba(19, 37, 27, .05);
  --shadow-md: 0 2px 4px rgba(19, 37, 27, .04), 0 10px 28px rgba(19, 37, 27, .08);
  --shadow-lg: 0 6px 12px rgba(19, 37, 27, .06), 0 22px 50px rgba(19, 37, 27, .11);
  --up: #12874a;
  --down: #c23b32;
  --soft2: #edf1ea;
  --hairline: color-mix(in srgb, var(--line) 72%, transparent);
  --ease: cubic-bezier(.22, .61, .36, 1);
}

/* ---- Motion opt-out ---- */
@media (prefers-reduced-motion: reduce) {
  [data-niche="moneyracket"] * { animation: none !important; transition: none !important; }
}

/* ---- Typography rhythm ---- */
[data-niche="moneyracket"] .cat-head h1,
[data-niche="moneyracket"] h1 { letter-spacing: -0.021em; line-height: 1.06; }
[data-niche="moneyracket"] .cat-head p { max-width: 64ch; line-height: 1.62; font-size: 16.5px; color: var(--muted); }
[data-niche="moneyracket"] .cat-tag,
[data-niche="moneyracket"] .eyebrow,
[data-niche="moneyracket"] .bt-cat { letter-spacing: .13em !important; font-weight: 600; }
[data-niche="moneyracket"] .front-title {
  letter-spacing: -0.01em; position: relative; padding-left: 13px;
}
[data-niche="moneyracket"] .front-title::before {
  content: ""; position: absolute; left: 0; top: 50%; transform: translateY(-50%);
  width: 4px; height: 1.05em; border-radius: 3px; background: var(--accent); opacity: .85;
}

/* ---- Numbers: tabular + tight ---- */
[data-niche="moneyracket"] .stat .v,
[data-niche="moneyracket"] .bt-basket,
[data-niche="moneyracket"] .mt-total,
[data-niche="moneyracket"] .bt-ret,
[data-niche="moneyracket"] .wret,
[data-niche="moneyracket"] .px,
[data-niche="moneyracket"] .chg { font-variant-numeric: tabular-nums; letter-spacing: -0.015em; }

/* ---- Cards: depth + hover lift ---- */
[data-niche="moneyracket"] .card,
[data-niche="moneyracket"] .pf-card,
[data-niche="moneyracket"] .mt-card,
[data-niche="moneyracket"] .bt-card,
[data-niche="moneyracket"] .chart-wrap,
[data-niche="moneyracket"] .cred-item {
  border-radius: var(--radius);
  border: 1px solid var(--hairline);
  box-shadow: var(--shadow-sm);
  transition: box-shadow .3s var(--ease), transform .3s var(--ease), border-color .3s var(--ease);
}
[data-niche="moneyracket"] .mt-card:hover,
[data-niche="moneyracket"] .bt-card:hover,
[data-niche="moneyracket"] .pf-card:hover {
  box-shadow: var(--shadow-md);
  transform: translateY(-3px);
  border-color: color-mix(in srgb, var(--accent) 30%, var(--hairline));
}
[data-niche="moneyracket"] .chart-wrap { box-shadow: var(--shadow-md); padding: 24px; }

/* ---- Stat cards: refined, subtle gradient, hairline ---- */
[data-niche="moneyracket"] .stat {
  border-radius: var(--radius);
  background: linear-gradient(180deg, var(--panel), color-mix(in srgb, var(--panel) 90%, var(--bg)));
  border: 1px solid var(--hairline);
  box-shadow: var(--shadow-xs);
  padding: 22px 24px;
}
[data-niche="moneyracket"] .stat .v { font-size: 30px; line-height: 1; }
[data-niche="moneyracket"] .stat .l { margin-top: 8px; font-size: 12.5px; letter-spacing: .01em; opacity: .85; }
[data-niche="moneyracket"] .stat-row { gap: 14px; }

/* ---- Semantic up/down everywhere ---- */
[data-niche="moneyracket"] .up { color: var(--up); }
[data-niche="moneyracket"] .down { color: var(--down); }

/* ---- Money Trail: cards, bars, sparklines ---- */
[data-niche="moneyracket"] .mt-tk { letter-spacing: .01em; }
[data-niche="moneyracket"] .mt-total { font-variant-numeric: tabular-nums; }
[data-niche="moneyracket"] .ag-bar { height: 12px; border-radius: 7px; background: var(--soft2); }
[data-niche="moneyracket"] .ag-bar span {
  border-radius: 7px;
  background: linear-gradient(90deg, color-mix(in srgb, var(--accent) 78%, #fff), var(--accent));
  transform-origin: left center; animation: mrGrowX .75s var(--ease) both;
}
[data-niche="moneyracket"] .mt-spark { opacity: .55; }

/* ---- Backtest: bars ---- */
[data-niche="moneyracket"] .bt-bar-wrap { background: var(--soft2); height: 13px; border-radius: 7px; }
[data-niche="moneyracket"] .bt-bar {
  border-radius: 7px; transform-origin: left center; animation: mrGrowX .7s var(--ease) both;
  transition: filter .2s var(--ease);
}
[data-niche="moneyracket"] .bt-bar.up { background: linear-gradient(90deg, color-mix(in srgb, var(--up) 72%, #fff), var(--up)); }
[data-niche="moneyracket"] .bt-bar.down { background: linear-gradient(90deg, color-mix(in srgb, var(--down) 72%, #fff), var(--down)); }
[data-niche="moneyracket"] .bt-play:hover .bt-bar { filter: brightness(1.06) saturate(1.1); }
[data-niche="moneyracket"] .bt-basket { font-size: 27px; }

/* ---- Catalyst Watch: rows, movers bars ---- */
[data-niche="moneyracket"] .watch-row {
  border-radius: var(--radius-sm); transition: background .2s var(--ease);
  padding: 13px 14px;
}
[data-niche="moneyracket"] .watch-row:hover { background: color-mix(in srgb, var(--accent) 5%, transparent); }
[data-niche="moneyracket"] .px { font-weight: 700; }
[data-niche="moneyracket"] svg .bar-row-v { font-variant-numeric: tabular-nums; font-weight: 600; }
/* movers bars: rounded + subtle entrance */
[data-niche="moneyracket"] .chart-wrap svg rect { transition: opacity .2s var(--ease); }
[data-niche="moneyracket"] .chart-wrap svg rect:hover { opacity: 1 !important; }

/* ---- SVG bar/line entrance for the leaderboard + trend ---- */
[data-niche="moneyracket"] .chart-wrap svg { animation: mrFade .6s var(--ease) both; }
[data-niche="moneyracket"] polyline { animation: mrDraw 1s var(--ease) both; }

/* ---- Buttons: gentle press ---- */
[data-niche="moneyracket"] .btn { transition: transform .16s var(--ease), box-shadow .16s var(--ease), filter .16s var(--ease); }
[data-niche="moneyracket"] .btn:hover { transform: translateY(-1px); filter: brightness(1.03); }
[data-niche="moneyracket"] .btn:active { transform: translateY(0); }
[data-niche="moneyracket"] .btn-gold { box-shadow: var(--shadow-sm); }

/* ---- Card grids: staggered rise-in ---- */
[data-niche="moneyracket"] .mt-grid > *,
[data-niche="moneyracket"] .bt-grid > *,
[data-niche="moneyracket"] .pf-grid > * { animation: mrRise .5s var(--ease) both; }
[data-niche="moneyracket"] .mt-grid > *:nth-child(2), [data-niche="moneyracket"] .bt-grid > *:nth-child(2) { animation-delay: .04s; }
[data-niche="moneyracket"] .mt-grid > *:nth-child(3), [data-niche="moneyracket"] .bt-grid > *:nth-child(3) { animation-delay: .08s; }
[data-niche="moneyracket"] .mt-grid > *:nth-child(4), [data-niche="moneyracket"] .bt-grid > *:nth-child(4) { animation-delay: .12s; }
[data-niche="moneyracket"] .mt-grid > *:nth-child(n+5), [data-niche="moneyracket"] .bt-grid > *:nth-child(n+5) { animation-delay: .16s; }

/* ---- Keyframes ---- */
@keyframes mrGrowX { from { transform: scaleX(0); } to { transform: scaleX(1); } }
@keyframes mrRise { from { opacity: 0; transform: translateY(12px); } to { opacity: 1; transform: none; } }
@keyframes mrFade { from { opacity: 0; } to { opacity: 1; } }
@keyframes mrDraw { from { opacity: 0; } to { opacity: 1; } }

/* =========================================================================
   REDESIGN v2 — bold sans headlines, market-pulse band, Gainers|Laggards
   ========================================================================= */

/* Modern bold sans headlines (override the serif on content headings only) */
[data-niche="moneyracket"] .cat-head h1,
[data-niche="moneyracket"] h1,
[data-niche="moneyracket"] h2,
[data-niche="moneyracket"] h3,
[data-niche="moneyracket"] .front-title {
  font-family: "Inter", -apple-system, BlinkMacSystemFont, "Segoe UI", system-ui, sans-serif !important;
}
[data-niche="moneyracket"] .cat-head h1, [data-niche="moneyracket"] h1 { font-weight: 800 !important; letter-spacing: -0.032em; }
[data-niche="moneyracket"] h2 { font-weight: 750 !important; letter-spacing: -0.02em; }
[data-niche="moneyracket"] h3 { font-weight: 700 !important; letter-spacing: -0.015em; }

/* Market-pulse band — .stat-row on every data page becomes a connected band */
[data-niche="moneyracket"] .mr-pulse,
[data-niche="moneyracket"] .stat-row {
  display: grid; grid-template-columns: repeat(auto-fit, minmax(150px, 1fr)); gap: 0;
  background: var(--panel); border: 1px solid var(--hairline); border-radius: 14px;
  overflow: hidden; box-shadow: var(--shadow-sm); margin: 22px 0 0;
}
[data-niche="moneyracket"] .mr-pulse { grid-template-columns: repeat(4, 1fr); }
[data-niche="moneyracket"] .pulse-item,
[data-niche="moneyracket"] .stat-row > .stat {
  padding: 16px 20px; border-right: 1px solid var(--hairline);
  background: transparent !important; box-shadow: none !important; border-radius: 0 !important; border-top: 0; border-bottom: 0; border-left: 0;
}
[data-niche="moneyracket"] .pulse-item:last-child,
[data-niche="moneyracket"] .stat-row > .stat:last-child { border-right: 0; }
[data-niche="moneyracket"] .pulse-v { font-size: 19px; font-weight: 800; letter-spacing: -0.02em; font-variant-numeric: tabular-nums; display: flex; align-items: center; gap: 6px; }
[data-niche="moneyracket"] .stat-row > .stat .v { font-size: 21px !important; }
[data-niche="moneyracket"] .pulse-l { font-size: 11.5px; color: var(--muted); margin-top: 6px; }
[data-niche="moneyracket"] .pulse-sep { color: var(--line); font-weight: 400; }
[data-niche="moneyracket"] .pulse-chip { font-size: 12px; font-weight: 700; padding: 2px 7px; border-radius: 6px; }
[data-niche="moneyracket"] .pulse-chip.up { color: var(--up); background: color-mix(in srgb, var(--up) 12%, transparent); }
[data-niche="moneyracket"] .pulse-chip.down { color: var(--down); background: color-mix(in srgb, var(--down) 12%, transparent); }

/* Movers — Gainers | Laggards split */
[data-niche="moneyracket"] .mr-movers { display: grid; grid-template-columns: 1fr 1fr; gap: 16px; margin-top: 16px; }
[data-niche="moneyracket"] .mv-col { background: var(--panel); border: 1px solid var(--hairline); border-radius: 14px; padding: 6px 6px 10px; box-shadow: var(--shadow-sm); }
[data-niche="moneyracket"] .mv-head { display: flex; align-items: center; gap: 8px; font-size: 13.5px; font-weight: 700; padding: 14px 14px 12px; letter-spacing: -0.01em; }
[data-niche="moneyracket"] .mv-arrow.up { color: var(--up); }
[data-niche="moneyracket"] .mv-arrow.down { color: var(--down); }
[data-niche="moneyracket"] .mv-count { margin-left: auto; font-size: 11px; font-weight: 500; color: var(--muted); }
[data-niche="moneyracket"] .mv-list { list-style: none; margin: 0; padding: 0; }
[data-niche="moneyracket"] .mv-list li { display: grid; grid-template-columns: 20px 54px 1fr 80px 66px; align-items: center; gap: 10px; padding: 9px 12px; border-radius: 9px; transition: background .15s var(--ease); }
[data-niche="moneyracket"] .mv-list li:hover { background: color-mix(in srgb, var(--accent) 6%, transparent); }
[data-niche="moneyracket"] .mv-rank { font-size: 11px; color: var(--muted); font-variant-numeric: tabular-nums; text-align: center; }
[data-niche="moneyracket"] .mv-tk { font-size: 13.5px; font-weight: 800; letter-spacing: .01em; }
[data-niche="moneyracket"] .mv-name { font-size: 12px; color: var(--muted); white-space: nowrap; overflow: hidden; text-overflow: ellipsis; }
[data-niche="moneyracket"] .mv-spark { width: 80px; height: 22px; }
[data-niche="moneyracket"] .mv-chg { font-size: 13px; font-weight: 800; text-align: right; font-variant-numeric: tabular-nums; }
[data-niche="moneyracket"] .mv-chg.up { color: var(--up); }
[data-niche="moneyracket"] .mv-chg.down { color: var(--down); }
[data-niche="moneyracket"] .mv-empty { padding: 16px 14px; color: var(--muted); font-size: 13px; }
[data-niche="moneyracket"] .mv-foot { font-size: 12px; color: var(--muted); margin-top: 14px; }
@media (max-width: 640px) {
  [data-niche="moneyracket"] .mr-movers { grid-template-columns: 1fr; }
  [data-niche="moneyracket"] .mr-pulse { grid-template-columns: 1fr 1fr; }
}
