/* ============================================================
   BoxingArena — Frontend Styles
   ============================================================ */

/* --- Variables --- */
:root {
  --ba-bg:       #111;
  --ba-bg2:      #1a1a1a;
  --ba-surface:  #222;
  --ba-border:   rgba(201,168,76,0.2);
  --ba-gold:     #c9a84c;
  --ba-red:      #c0392b;
  --ba-blue:     #2980b9;
  --ba-win:      #27ae60;
  --ba-text:     #f0ede6;
  --ba-muted:    #888;
  --ba-radius:   4px;
  --ba-font:     inherit;
}

.ba-widget { font-family: var(--ba-font); color: var(--ba-text); }

/* --- States --- */
.ba-loading, .ba-searching {
  display: block; padding: 12px 0;
  color: var(--ba-muted); font-size: 13px; font-style: italic;
}
.ba-empty   { color: var(--ba-muted); font-style: italic; padding: 8px 0; }
.ba-error   { color: var(--ba-red); background: rgba(192,57,43,.08);
              padding: 8px 12px; border-left: 3px solid var(--ba-red); font-size: 13px; }
.ba-odds-updated { font-size: 11px; color: var(--ba-muted); text-align: right; margin: 6px 0 0; }

/* --- Base Table --- */
.ba-table { width: 100%; border-collapse: collapse; font-size: 14px; }
.ba-table th {
  background: var(--ba-bg); color: var(--ba-gold);
  text-transform: uppercase; font-size: 11px; letter-spacing: 1.5px;
  padding: 10px 14px; text-align: left; white-space: nowrap;
}
.ba-table td { padding: 10px 14px; border-bottom: 1px solid rgba(255,255,255,.06); vertical-align: middle; }
.ba-table tr:last-child td { border-bottom: none; }
.ba-table tr:hover td { background: rgba(201,168,76,.04); }
.ba-fighter-a    { color: var(--ba-red);  font-weight: 600; }
.ba-fighter-b    { color: var(--ba-blue); font-weight: 600; }
.ba-odds-val     { font-weight: 700; font-size: 16px; }
.ba-fc-odd--a    { color: var(--ba-red); }
.ba-fc-odd--b    { color: var(--ba-blue); }
.ba-fc-odd--best { background: rgba(201,168,76,.12); border-radius: 2px; }

/* ============================================================
   FIGHT CARD
   ============================================================ */
.ba-fight-card {
  background: var(--ba-bg); border: 1px solid var(--ba-border);
  max-width: 620px; font-size: 14px;
}

/* Event header */
.ba-fc-event {
  background: var(--ba-bg2); padding: 12px 20px;
  border-bottom: 1px solid var(--ba-border);
  display: flex; flex-wrap: wrap; align-items: center; gap: 10px;
}
.ba-fc-title-badge {
  background: rgba(201,168,76,.15); color: var(--ba-gold);
  font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase;
  padding: 3px 10px; border: 1px solid var(--ba-border);
}
.ba-fc-event-name { font-weight: 600; }
.ba-fc-date, .ba-fc-venue { color: var(--ba-muted); font-size: 12px; margin-left: auto; }

/* Matchup row */
.ba-fc-matchup {
  display: grid; grid-template-columns: 1fr auto 1fr;
  gap: 16px; padding: 24px 20px; align-items: center;
}
.ba-fc-fighter { display: flex; flex-direction: column; align-items: center; gap: 8px; }
.ba-fc-fighter--a { align-items: flex-start; }
.ba-fc-fighter--b { align-items: flex-end;   }

.ba-fc-avatar {
  width: 60px; height: 60px; border-radius: 50%;
  background: var(--ba-surface); border: 2px solid var(--ba-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 18px; font-weight: 700; letter-spacing: 1px;
}
.ba-fc-avatar--red  { border-color: var(--ba-red);  color: var(--ba-red); }
.ba-fc-avatar--blue { border-color: var(--ba-blue); color: var(--ba-blue); }

.ba-fc-name      { font-size: 18px; font-weight: 700; text-align: center; }
.ba-fc-record    { font-size: 12px; color: var(--ba-muted); }
.ba-fc-best-odds { font-size: 13px; color: var(--ba-muted); }
.ba-fc-best-odds strong { color: var(--ba-gold); }

.ba-fc-vs        { display: flex; flex-direction: column; align-items: center; gap: 4px; }
.ba-fc-vs-text   { font-size: 24px; font-weight: 900; color: var(--ba-muted); letter-spacing: 2px; }
.ba-fc-division  { font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ba-gold); }
.ba-fc-rounds    { font-size: 11px; color: var(--ba-muted); }

/* Probability bar */
.ba-fc-prob-section { padding: 0 20px 16px; }
.ba-fc-prob-labels  {
  display: flex; justify-content: space-between;
  font-size: 11px; color: var(--ba-muted); margin-bottom: 6px;
}
.ba-fc-prob-title { color: var(--ba-gold); letter-spacing: 1px; text-transform: uppercase; }
.ba-fc-prob-bar   {
  height: 10px; background: var(--ba-surface);
  display: flex; border-radius: 2px; overflow: hidden;
}
.ba-fc-prob-fill--a {
  background: var(--ba-red); height: 100%;
  display: flex; align-items: center; padding-left: 6px;
  font-size: 10px; color: #fff; transition: width .6s ease;
}
.ba-fc-prob-fill--b {
  background: var(--ba-blue); flex: 1; height: 100%;
  display: flex; align-items: center; justify-content: flex-end; padding-right: 6px;
  font-size: 10px; color: #fff; transition: width .6s ease;
}

/* Odds section */
.ba-fc-odds-section { border-top: 1px solid var(--ba-border); }
.ba-fc-odds-header  {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  padding: 8px 14px; background: var(--ba-bg2);
  font-size: 11px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ba-muted);
}
.ba-fc-odds-row {
  display: grid; grid-template-columns: 1fr 1fr 1fr;
  padding: 10px 14px; border-top: 1px solid rgba(255,255,255,.04);
  transition: background .15s;
}
.ba-fc-odds-row:hover { background: rgba(255,255,255,.03); }
.ba-fc-bm-name { font-size: 13px; }
.ba-fc-odd     { font-weight: 700; font-size: 16px; }

/* Result banner */
.ba-fc-result {
  background: rgba(39,174,96,.1); border-top: 1px solid rgba(39,174,96,.25);
  padding: 12px 20px; display: flex; align-items: center; gap: 12px;
}
.ba-fc-result-label  { font-size: 11px; letter-spacing: 2px; text-transform: uppercase; color: #27ae60; }
.ba-fc-result-winner { font-weight: 700; }
.ba-fc-result-method { color: var(--ba-muted); font-size: 13px; }

/* ============================================================
   FIGHTER STATS
   ============================================================ */
.ba-fighter-stats {
  background: var(--ba-bg); border: 1px solid var(--ba-border); max-width: 560px;
}

.ba-fs-header {
  display: flex; align-items: center; gap: 20px;
  padding: 24px 20px; border-bottom: 1px solid var(--ba-border);
  flex-wrap: wrap;
}
.ba-fs-avatar {
  width: 64px; height: 64px; border-radius: 50%;
  background: var(--ba-surface); border: 2px solid var(--ba-border);
  display: flex; align-items: center; justify-content: center;
  font-size: 20px; font-weight: 800; color: var(--ba-gold); flex-shrink: 0;
}
.ba-fs-name     { font-size: 22px; font-weight: 700; margin: 0 0 4px; }
.ba-fs-nickname { font-size: 13px; color: var(--ba-gold); font-style: italic; margin-bottom: 6px; }
.ba-fs-meta     { font-size: 12px; color: var(--ba-muted); display: flex; gap: 6px; flex-wrap: wrap; }
.ba-fs-divider  { color: var(--ba-border); }

.ba-fs-record-block { margin-left: auto; text-align: right; }
.ba-fs-record-nums  { font-size: 28px; font-weight: 900; letter-spacing: 2px; }
.ba-fs-w  { color: var(--ba-win); }
.ba-fs-l  { color: var(--ba-red); }
.ba-fs-d  { color: var(--ba-gold); }
.ba-fs-sep { color: var(--ba-muted); }
.ba-fs-record-label { font-size: 10px; letter-spacing: 2px; text-transform: uppercase; color: var(--ba-muted); margin-top: 2px; }
.ba-fs-kos { font-size: 12px; color: var(--ba-red); margin-top: 4px; font-weight: 600; }

/* Physical */
.ba-fs-physical {
  display: flex; flex-wrap: wrap; gap: 0;
  border-bottom: 1px solid var(--ba-border);
}
.ba-fs-phys-item {
  flex: 1 1 25%; min-width: 100px;
  padding: 12px 16px; border-right: 1px solid rgba(255,255,255,.05);
  display: flex; flex-direction: column; gap: 3px;
}
.ba-fs-phys-item:last-child { border-right: none; }
.ba-fs-phys-label { font-size: 10px; letter-spacing: 1.5px; text-transform: uppercase; color: var(--ba-muted); }
.ba-fs-phys-val   { font-size: 15px; font-weight: 600; }

/* Win bar */
.ba-fs-record-bar-section { padding: 16px 20px; border-bottom: 1px solid var(--ba-border); }
.ba-fs-record-bar { height: 28px; display: flex; border-radius: 2px; overflow: hidden; }
.ba-fs-bar-w { background: var(--ba-win);  display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #fff; min-width: 32px; transition: width .6s; }
.ba-fs-bar-d { background: var(--ba-gold); display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #111; }
.ba-fs-bar-l { background: var(--ba-red);  display: flex; align-items: center; justify-content: center; font-size: 12px; font-weight: 700; color: #fff; min-width: 24px; transition: width .6s; }

.ba-fs-ko-bar-wrap { display: flex; align-items: center; gap: 10px; margin-top: 10px; }
.ba-fs-ko-label    { font-size: 11px; color: var(--ba-muted); white-space: nowrap; min-width: 56px; }
.ba-fs-ko-bar      { flex: 1; height: 6px; background: var(--ba-surface); border-radius: 3px; overflow: hidden; }
.ba-fs-ko-fill     { height: 100%; background: var(--ba-red); transition: width .6s; }
.ba-fs-ko-pct      { font-size: 12px; font-weight: 700; color: var(--ba-red); min-width: 36px; text-align: right; }

/* Stats grid */
.ba-fs-stats-grid { display: flex; flex-wrap: wrap; padding: 8px 12px 16px; }
.ba-fs-stats-title {
  width: 100%; font-size: 10px; letter-spacing: 2px; text-transform: uppercase;
  color: var(--ba-gold); padding: 12px 4px 8px;
}
.ba-fs-stat-item {
  flex: 1 1 25%; min-width: 100px;
  padding: 10px 4px; display: flex; flex-direction: column; gap: 3px;
}
.ba-fs-stat-val { font-size: 18px; font-weight: 700; color: var(--ba-gold); }
.ba-fs-stat-key { font-size: 10px; letter-spacing: 1px; text-transform: uppercase; color: var(--ba-muted); }

/* ============================================================
   RESULTS TABLE
   ============================================================ */
.ba-fight-results { max-width: 860px; }
.ba-result-winner { font-weight: 700; color: var(--ba-win) !important; }
.ba-result-loser  { color: var(--ba-muted); }
.ba-result-date   { color: var(--ba-muted); white-space: nowrap; font-size: 12px; }

.ba-method-badge {
  display: inline-block; padding: 3px 8px; border-radius: 2px;
  font-size: 11px; letter-spacing: 1px; text-transform: uppercase; font-weight: 700;
}
.ba-method-ko  { background: rgba(192,57,43,.15); color: var(--ba-red); }
.ba-method-dec { background: rgba(41,128,185,.15); color: var(--ba-blue); }
.ba-method-draw{ background: rgba(201,168,76,.15); color: var(--ba-gold); }

/* ============================================================
   UPCOMING FIGHTS WIDGET
   ============================================================ */
.ba-widget-fights-list { list-style: none; margin: 0; padding: 0; }
.ba-wfl-item {
  display: flex; align-items: center; justify-content: space-between;
  padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.05); font-size: 13px;
}
.ba-wfl-item:last-child { border-bottom: none; }
.ba-wfl-fighters em { color: var(--ba-muted); font-style: normal; margin: 0 4px; }
.ba-wfl-date { font-size: 11px; color: var(--ba-gold); white-space: nowrap; margin-left: 8px; }

/* ============================================================
   ODDS TICKER WIDGET
   ============================================================ */
.ba-widget-odds-list { list-style: none; margin: 0; padding: 0; }
.ba-wol-item {
  padding: 8px 0; border-bottom: 1px solid rgba(255,255,255,.05); font-size: 13px;
}
.ba-wol-item:last-child { border-bottom: none; }
.ba-wol-matchup { margin-bottom: 4px; }
.ba-wol-odds    { display: flex; gap: 8px; align-items: center; }
.ba-wol-odd     { font-weight: 700; font-size: 16px; }
.ba-wol-odd--a  { color: var(--ba-red); }
.ba-wol-odd--b  { color: var(--ba-blue); }
.ba-wol-sep     { color: var(--ba-muted); }

/* ============================================================
   FIGHTER SEARCH WIDGET
   ============================================================ */
.ba-fighter-search-widget { position: relative; }
.ba-search-input {
  width: 100%; padding: 9px 12px; background: var(--ba-surface);
  border: 1px solid var(--ba-border); color: var(--ba-text);
  font-size: 14px; border-radius: var(--ba-radius); outline: none;
}
.ba-search-input:focus { border-color: var(--ba-gold); }

.ba-search-results {
  position: absolute; top: 100%; left: 0; right: 0; z-index: 999;
  background: var(--ba-bg2); border: 1px solid var(--ba-border);
  border-top: none; max-height: 300px; overflow-y: auto;
}
.ba-search-list  { list-style: none; margin: 0; padding: 0; }
.ba-search-item  {
  padding: 10px 14px; cursor: pointer; border-bottom: 1px solid rgba(255,255,255,.05);
  transition: background .15s;
}
.ba-search-item:hover { background: rgba(201,168,76,.08); }
.ba-search-item strong { display: block; font-size: 14px; }
.ba-search-meta  { font-size: 12px; color: var(--ba-muted); }

/* ============================================================
   ODDS EVENT BLOCK (standalone)
   ============================================================ */
.ba-odds-event { margin-bottom: 24px; }
.ba-odds-header {
  display: flex; align-items: center; gap: 10px; padding: 12px 0; flex-wrap: wrap;
}
.ba-odds-header .ba-vs { color: var(--ba-muted); font-weight: 700; }
.ba-date { margin-left: auto; font-size: 12px; color: var(--ba-muted); }

.ba-prob-bar    { display: flex; height: 8px; overflow: hidden; margin: 6px 0 12px; background: var(--ba-surface); }
.ba-prob-a      { background: var(--ba-red);  height: 100%; display:flex; align-items:center; padding-left:5px; font-size:10px; color:#fff; }
.ba-prob-b      { background: var(--ba-blue); flex:1; height:100%; display:flex; align-items:center; justify-content:flex-end; padding-right:5px; font-size:10px; color:#fff; }

/* ============================================================
   RESPONSIVE
   ============================================================ */
@media (max-width: 580px) {
  .ba-fc-matchup        { grid-template-columns: 1fr; text-align: center; }
  .ba-fc-fighter--a,
  .ba-fc-fighter--b     { align-items: center; }
  .ba-fc-vs             { flex-direction: row; justify-content: center; }
  .ba-fc-odds-header,
  .ba-fc-odds-row       { grid-template-columns: 2fr 1fr 1fr; }
  .ba-table th:nth-child(n+4),
  .ba-table td:nth-child(n+4) { display: none; }
  .ba-fs-record-block   { margin-left: 0; text-align: left; }
  .ba-fs-header         { flex-direction: column; align-items: flex-start; }
}

/* ============================================================
   STATUS BADGES
   ============================================================ */
.ba-status-badge   { display:inline-block; padding:3px 10px; font-size:11px; letter-spacing:1.5px; text-transform:uppercase; font-weight:700; }
.ba-status-live    { background:rgba(192,57,43,.2); color:#ff4136; animation:ba-blink 1.5s infinite; }
.ba-status-upcoming{ background:rgba(41,128,185,.15); color:#2980b9; }
.ba-status-finished{ background:rgba(136,136,136,.15); color:#888; }
@keyframes ba-blink { 0%,100%{opacity:1} 50%{opacity:.5} }

/* ============================================================
   FIGHT CARD EXTRAS (v2)
   ============================================================ */
.ba-fc-titles-bar {
  display:flex; flex-wrap:wrap; gap:6px;
  padding:8px 20px; border-bottom:1px solid var(--ba-border);
  background:rgba(201,168,76,.05);
}
.ba-fc-belt {
  font-size:12px; color:var(--ba-gold); letter-spacing:.5px;
}
.ba-fc-winner-crown {
  font-size:12px; color:#f1c40f; font-weight:700; margin-top:2px;
}
.ba-fc-fighter--winner .ba-fc-name { color:var(--ba-win); }
.ba-fc-avatar--won { border-color:var(--ba-win) !important; box-shadow:0 0 0 2px rgba(39,174,96,.2); }
.ba-fc-result-scores { font-size:12px; color:var(--ba-muted); margin-left:8px; }
.ba-fc-broadcasters {
  display:flex; flex-wrap:wrap; align-items:center; gap:12px;
  padding:10px 20px; border-top:1px solid var(--ba-border);
  font-size:12px; color:var(--ba-muted);
}
.ba-fc-bc-label { color:var(--ba-text); font-weight:600; }
.ba-fc-bc-item  { color:var(--ba-muted); }

/* ============================================================
   WEIGHT + TITLE in upcoming table
   ============================================================ */
.ba-weight-limit { display:block; font-size:11px; color:var(--ba-muted); }
.ba-title-badge  { font-size:11px; color:var(--ba-gold); letter-spacing:1px; }

/* ============================================================
   UPCOMING EVENTS
   ============================================================ */
.ba-upcoming-events { max-width:860px; }
