/* ════════════════════════════════════════════════════════════════════
   winloss.css · craps/win-loss-feedback/v1 · DH #240 / epic #3146
   ────────────────────────────────────────────────────────────────────
   Win/Loss feedback layer for the LIVE LiveRoll felt + collapsed cards.
   Lights up the classes the app ALREADY applies (.zone.flash-win /
   .flash-loss, .chip-mini.state-winning / .state-losing) — these had NO
   styling, so resolutions came & went invisibly (Murphy 2026-06-03:
   "not clear at all when I'm winning/losing"). Adds the WON banner +
   count-up, the muted -$N / SEVEN OUT loss tag, and the collapsed-card
   result pill. MOTION_SYSTEM §2: slow, weighty, easeOutCubic, NO bounce,
   NO punitive red. Glory-only. Honors prefers-reduced-motion.
   Tokens: live --lr-* (liveroll-theme.css).
   ════════════════════════════════════════════════════════════════════ */
:root { --wl-ease: var(--lr-ease, cubic-bezier(0.215,0.61,0.355,1)); }

/* ─── WIN · gold ring pulse + settled fill on each winning zone ─── */
.zone.flash-win {
  border-color: rgba(232,200,117,0.55) !important;
  background: rgba(212,168,67,0.14) !important;
  z-index: 3;
}
.zone.flash-win::after {
  content:''; position:absolute; inset:-2px; border-radius:6px;
  border:2px solid rgba(232,200,117,0.85);
  box-shadow:0 0 14px rgba(232,200,117,0.45);
  opacity:0; pointer-events:none; z-index:4;
  animation: wl-ring 900ms var(--wl-ease) 1;
}
@keyframes wl-ring {
  0%   { opacity:0; transform:scale(0.55); }
  18%  { opacity:1; }
  100% { opacity:0; transform:scale(1.5); }
}
/* winning chips light up while paying */
.zone.flash-win .chip-mini,
.chip-mini.state-winning {
  border-color: var(--lr-gold-soft) !important;
  box-shadow:0 0 0 1px var(--lr-gold-soft), 0 0 12px rgba(232,200,117,0.5) !important;
}
.zone.flash-win .stack-total {
  color:#1a1305 !important; background:var(--lr-gold-soft) !important; border-color:var(--lr-gold-soft) !important;
}

/* ─── LOSS · clean muted drop (no red, no shake) ─── */
.zone.flash-loss {
  background: rgba(255,255,255,0.015) !important;
  border-color: var(--lr-edge) !important;
  opacity:0.5; filter:saturate(0.4);
  transform:translateY(4px);
  transition: opacity 520ms var(--wl-ease), filter 520ms var(--wl-ease),
              transform 520ms var(--wl-ease), background 520ms var(--wl-ease);
}
.zone.flash-loss .num,
.zone.flash-loss .zone-lbl,
.zone.flash-loss .field-lbl { color: var(--lr-ink-faint) !important; }
.zone.flash-loss .chip-mini,
.chip-mini.state-losing {
  opacity:0; transform:translateY(6px);
  transition: opacity 420ms var(--wl-ease), transform 420ms var(--wl-ease);
}

/* ─── WON banner crossing the felt ─── */
.felt .felt-banner {
  position:absolute; top:50%; left:50%; z-index:12;
  transform:translate(-50%,-50%);
  display:inline-flex; align-items:center; gap:12px;
  padding:9px 16px; border-radius:8px;
  background:rgba(10,13,16,0.96);
  border:1px solid var(--lr-gold);
  box-shadow:0 10px 30px rgba(0,0,0,0.6), 0 0 44px rgba(212,168,67,0.28);
  pointer-events:none; white-space:nowrap; max-width:94%;
  animation: wl-banner-cross 1780ms var(--wl-ease) 1 both;
}
@keyframes wl-banner-cross {
  0%   { opacity:0; transform:translate(-50%,-50%) translateX(-16px); }
  20%  { opacity:1; transform:translate(-50%,-50%); }
  82%  { opacity:1; transform:translate(-50%,-50%); }
  100% { opacity:0; transform:translate(-50%,-50%) translateX(14px); }
}
.felt-banner-word { font-family:'Barlow Condensed',sans-serif; font-size:20px; font-weight:900; letter-spacing:0.10em; color:var(--lr-gold-soft); text-transform:uppercase; line-height:1; }
.felt-banner-sep  { width:1px; height:26px; background:var(--lr-edge-2); }
.felt-banner-pay  { display:flex; flex-direction:column; gap:3px; min-width:0; }
.felt-banner-amt  { font-family:'JetBrains Mono',monospace; font-weight:700; font-size:22px; color:var(--lr-gold-soft); line-height:1; font-variant-numeric:tabular-nums; }
.felt-banner-lines{ display:flex; gap:8px; flex-wrap:wrap; }
.felt-banner-line { font-family:'JetBrains Mono',monospace; font-size:8px; letter-spacing:0.04em; color:var(--lr-ink-dim); white-space:nowrap; }
.felt-banner-line b { color:var(--lr-win); font-weight:700; }
/* push variant — neutral, no celebration */
.felt-banner.is-push { border-color:var(--lr-edge-2); box-shadow:0 10px 30px rgba(0,0,0,0.6); }
.felt-banner.is-push .felt-banner-word { color:var(--lr-ink); }
.felt-banner.is-push .felt-banner-amt  { color:var(--lr-ink-dim); }

/* ─── -$N / SEVEN OUT loss tag (dim, never red) ─── */
.felt .felt-losstag {
  position:absolute; top:50%; left:50%; z-index:12;
  transform:translate(-50%,-50%);
  display:inline-flex; align-items:center; gap:10px;
  padding:8px 15px; border-radius:8px;
  background:rgba(14,20,24,0.96);
  border:1px solid var(--lr-edge-2);
  box-shadow:0 10px 30px rgba(0,0,0,0.55);
  pointer-events:none; white-space:nowrap; max-width:94%;
  animation: wl-losstag 1780ms var(--wl-ease) 1 both;
}
@keyframes wl-losstag {
  0%   { opacity:0; transform:translate(-50%,-50%) translateY(6px); }
  18%  { opacity:1; transform:translate(-50%,-50%); }
  82%  { opacity:1; transform:translate(-50%,-50%); }
  100% { opacity:0; transform:translate(-50%,-50%) translateY(-4px); }
}
.felt-losstag-word { font-family:'Barlow Condensed',sans-serif; font-size:16px; font-weight:800; letter-spacing:0.16em; color:var(--lr-ink-dim); text-transform:uppercase; line-height:1; }
.felt-losstag-sep  { width:1px; height:22px; background:var(--lr-edge-2); }
.felt-losstag-amt  { font-family:'JetBrains Mono',monospace; font-weight:700; font-size:18px; color:var(--lr-ink-dim); line-height:1; font-variant-numeric:tabular-nums; }
.felt-losstag-down { font-family:'JetBrains Mono',monospace; font-size:8px; letter-spacing:0.08em; color:var(--lr-ink-faint); margin-top:3px; text-transform:uppercase; }

/* ─── Collapsed feed-card result pill + edge-pulse ─── */
.ccard-result-pill {
  display:inline-flex; align-items:center; gap:5px;
  font-family:'JetBrains Mono',monospace; font-weight:700; font-size:11px;
  letter-spacing:0.03em; line-height:1; padding:4px 8px; border-radius:999px;
  animation: wl-pill-in 480ms var(--wl-ease) 1 both;
}
@keyframes wl-pill-in { 0% { opacity:0; transform:translateY(3px) scale(0.94); } 100% { opacity:1; transform:none; } }
.ccard-result-pill .arr { font-family:'Barlow Condensed',sans-serif; font-size:10px; }
.ccard-result-pill .lbl { font-family:'Barlow Condensed',sans-serif; font-size:9px; font-weight:800; letter-spacing:0.14em; }
.ccard-result-pill.wl-win  { background:rgba(212,168,67,0.16); color:var(--lr-gold-soft); }
.ccard-result-pill.wl-loss { background:rgba(240,240,236,0.07); color:var(--lr-ink-dim); }
.ccard.wl-flash::after {
  content:''; position:absolute; inset:0; border-radius:inherit; pointer-events:none; opacity:0; z-index:3;
}
.ccard.wl-flash.wl-win::after  { animation: wl-edge-win 480ms var(--wl-ease) 1 both; }
.ccard.wl-flash.wl-loss::after { animation: wl-edge-loss 480ms var(--wl-ease) 1 both; }
@keyframes wl-edge-win {
  0%   { opacity:0; box-shadow:inset 0 0 0 1px rgba(232,200,117,0); }
  40%  { opacity:1; box-shadow:inset 0 0 0 1.5px rgba(232,200,117,0.9), inset 0 0 20px rgba(232,200,117,0.25); }
  100% { opacity:1; box-shadow:inset 0 0 0 1px rgba(232,200,117,0.45); }
}
@keyframes wl-edge-loss {
  0%   { opacity:0; box-shadow:inset 0 0 0 1px rgba(240,240,236,0); }
  40%  { opacity:1; box-shadow:inset 0 0 0 1px rgba(240,240,236,0.22); }
  100% { opacity:0.7; box-shadow:inset 0 0 0 1px rgba(240,240,236,0.10); }
}

/* ─── reduced motion — keep the resolved figure, drop the motion ─── */
@media (prefers-reduced-motion: reduce) {
  .zone.flash-win::after, .ccard.wl-flash::after,
  .felt .felt-banner, .felt .felt-losstag, .ccard-result-pill { animation:none !important; }
  .felt .felt-banner, .felt .felt-losstag { opacity:1 !important; }
  .ccard-result-pill { opacity:1 !important; transform:none !important; }
  .zone.flash-loss { transition:none !important; }
}
