
/* ============================================================
   FF Hub Hi-Fi Components
   League / Team / Player hub pages
   ============================================================ */

/* ---- Hub Hero (League / Team) ---- */
.ff-hub-hero {
  border: 1px solid var(--ff-color-border);
  border-radius: var(--ff-radius);
  background: var(--ff-color-card);
  overflow: hidden;
}
.ff-hub-hero__head {
  display: flex;
  align-items: flex-start;
  gap: 14px;
  padding: 18px 18px 14px;
  border-left: 5px solid var(--ff-hub-accent, var(--ff-color-primary));
  position: relative;
}
.ff-hub-hero__badge {
  flex: 0 0 auto;
  width: 44px; height: 44px;
  border-radius: var(--ff-radius);
  background: var(--ff-hub-accent, var(--ff-color-primary));
  color: #fff;
  display: flex; align-items: center; justify-content: center;
  font: 800 14px/1 var(--ff-font-display);
  letter-spacing: 0;
}
.ff-hub-hero__info { min-width: 0; flex: 1; }
.ff-hub-hero__title {
  margin: 0 0 4px;
  font: 800 22px/1.1 var(--ff-font-display);
  letter-spacing: 0;
}
.ff-hub-hero__sub { margin: 0; color: var(--ff-color-muted); font-size: 12px; }
.ff-hub-hero__status {
  flex: 0 0 auto;
  align-self: flex-start;
  padding: 3px 9px;
  border-radius: var(--ff-radius-pill);
  background: var(--ff-hub-accent, var(--ff-color-primary));
  color: #fff;
  font: 700 11px/1 var(--ff-font-mono);
  white-space: nowrap;
}

/* Stats strip */
.ff-hub-hero__strip {
  display: grid;
  grid-template-columns: repeat(4, minmax(0,1fr));
  border-top: 1px solid var(--ff-color-border);
}
.ff-hub-hero__strip-item {
  padding: 12px 14px;
  border-right: 1px solid var(--ff-color-border);
  display: flex; flex-direction: column; gap: 4px;
}
.ff-hub-hero__strip-item:last-child { border-right: 0; }
.ff-hub-hero__strip-item strong {
  font: 800 22px/1 var(--ff-font-display);
  color: var(--ff-color-primary-text);
}
.ff-hub-hero__strip-item span { color: var(--ff-color-muted); font: 500 11px/1 var(--ff-font-mono); }

/* Form / meta row */
.ff-hub-hero__form-row {
  padding: 10px 14px;
  border-top: 1px solid var(--ff-color-border);
  display: flex; align-items: center; gap: 14px; flex-wrap: wrap;
}
.ff-hub-hero__form-label { color: var(--ff-color-muted); font: 500 11px/1 var(--ff-font-mono); white-space: nowrap; }
.ff-hub-hero__form-dots { display: flex; gap: 3px; }
.ff-hub-hero__meta { color: var(--ff-color-muted); font-size: 11px; }
.ff-hub-hero__meta span::before { content: " · "; }

/* Embedded next-match card */
.ff-hub-hero__next-match {
  display: flex; align-items: center; justify-content: space-between; gap: 12px; flex-wrap: wrap;
  margin: 0 14px 14px;
  padding: 11px 14px;
  border: 1px solid rgba(59,130,246,.3);
  border-radius: var(--ff-radius);
  background: rgba(59,130,246,.06);
  text-decoration: none;
  transition: border-color .14s, background .14s;
}
.ff-hub-hero__next-match:hover { border-color: rgba(59,130,246,.55); background: rgba(59,130,246,.10); }
.ff-hub-hero__next-match-left { display: flex; flex-direction: column; gap: 5px; }
.ff-hub-hero__next-match-chip {
  color: var(--ff-color-primary-text);
  font: 700 10px/1 var(--ff-font-mono);
  text-transform: uppercase; letter-spacing: 0.04em;
}
.ff-hub-hero__next-match-teams { font-size: 13px; font-weight: 700; }
.ff-hub-hero__next-match-right { display: flex; align-items: center; gap: 10px; flex-shrink: 0; }
.ff-hub-hero__next-match-meta { color: var(--ff-color-muted); font: 500 12px/1.4 var(--ff-font-mono); text-align: right; }
.ff-hub-hero__next-match-arrow { color: var(--ff-color-primary-text); font-size: 16px; }

/* ---- Player Hero v2 ---- */
.ff-player-hero-v2 {
  border: 1px solid var(--ff-color-border);
  border-radius: var(--ff-radius);
  background: var(--ff-color-card);
  overflow: hidden;
}
.ff-player-hero-v2__top {
  padding: 18px 18px 14px;
  border-left: 5px solid var(--ff-color-primary);
}
.ff-player-hero-v2__num-badge {
  display: inline-block; margin-bottom: 8px; padding: 2px 8px;
  border-radius: var(--ff-radius);
  background: var(--ff-color-primary-soft); color: var(--ff-color-primary-text);
  font: 800 12px/1.5 var(--ff-font-mono);
}
.ff-player-hero-v2__name-ja { margin: 0 0 3px; font: 800 22px/1.1 var(--ff-font-display); }
.ff-player-hero-v2__name-en { color: var(--ff-color-muted); font: 500 12px/1 var(--ff-font-mono); }
.ff-player-hero-v2__cols {
  display: grid; grid-template-columns: 1fr 1fr;
  border-top: 1px solid var(--ff-color-border);
}
.ff-player-hero-v2__col { padding: 14px; }
.ff-player-hero-v2__col + .ff-player-hero-v2__col { border-left: 1px solid var(--ff-color-border); }
.ff-player-hero-v2__col-label {
  display: block; margin-bottom: 10px;
  color: var(--ff-color-muted);
  font: 700 10px/1 var(--ff-font-mono);
  text-transform: uppercase; letter-spacing: 0.05em;
}
.ff-player-hero-v2__club-link {
  display: flex; align-items: center; gap: 7px; margin-bottom: 6px;
  color: var(--ff-color-primary-text); font-size: 14px; font-weight: 700;
}
.ff-player-hero-v2__club-link:hover { text-decoration: underline; }
.ff-player-hero-v2__club-badge {
  width: 22px; height: 22px; border-radius: 4px;
  background: var(--ff-color-primary); color: #fff;
  display: inline-flex; align-items: center; justify-content: center;
  font: 800 9px/1 var(--ff-font-display); flex: 0 0 auto;
}
.ff-player-hero-v2__club-sub { color: var(--ff-color-muted); font-size: 12px; margin-bottom: 10px; }
.ff-player-hero-v2__col dl { margin: 0; display: grid; grid-template-columns: auto 1fr; gap: 5px 12px; }
.ff-player-hero-v2__col dt { color: var(--ff-color-muted); font-size: 12px; }
.ff-player-hero-v2__col dd { margin: 0; font-size: 12px; font-weight: 600; }

/* Trophy row */
.ff-trophy-row {
  padding: 10px 14px; border-top: 1px solid var(--ff-color-border);
  display: flex; gap: 8px; flex-wrap: wrap; align-items: center;
}
.ff-trophy-row__label { color: var(--ff-color-muted); font: 700 10px/1 var(--ff-font-mono); text-transform: uppercase; letter-spacing: 0.05em; }
.ff-trophy-item {
  display: inline-flex; align-items: center; gap: 4px;
  padding: 3px 8px; border-radius: var(--ff-radius-pill);
  background: rgba(255,255,255,.06); border: 1px solid var(--ff-color-border);
  font: 600 11px/1 var(--ff-font-mono); color: var(--ff-color-text);
}
.ff-trophy-item__count { color: var(--ff-color-primary-text); font-weight: 800; }

/* Player strip */
.ff-player-hero-v2__strip {
  display: grid; grid-template-columns: repeat(3, minmax(0,1fr));
  border-top: 1px solid var(--ff-color-border);
}
.ff-player-hero-v2__strip-item {
  padding: 12px 14px; border-right: 1px solid var(--ff-color-border);
  display: flex; flex-direction: column; gap: 4px;
}
.ff-player-hero-v2__strip-item:last-child { border-right: 0; }
.ff-player-hero-v2__strip-item strong { font: 800 22px/1 var(--ff-font-display); color: var(--ff-color-primary-text); }
.ff-player-hero-v2__strip-item span { color: var(--ff-color-muted); font: 500 11px/1 var(--ff-font-mono); }

/* ---- Intro prose ---- */
.ff-hub-intro {
  border: 1px solid var(--ff-color-border); border-radius: var(--ff-radius);
  background: var(--ff-color-card); padding: 18px;
}
.ff-hub-intro h2 { margin: 0 0 10px; font: 800 16px/1.3 var(--ff-font-display); }
.ff-hub-intro p { margin: 0 0 10px; color: var(--ff-color-muted); font-size: 14px; line-height: 1.75; }
.ff-hub-intro p:last-child { margin-bottom: 0; }

/* ---- Tabgroup ---- */
.ff-tabgroup__header {
  display: flex; align-items: center; justify-content: space-between; gap: 12px;
  border-bottom: 1px solid var(--ff-color-border); padding-right: 14px; flex-wrap: wrap;
}
.ff-tabgroup .ff-tabbar { border-bottom: 0; }
.ff-tabgroup__update { color: var(--ff-color-muted); font: 500 11px/1 var(--ff-font-mono); white-space: nowrap; flex-shrink: 0; }

/* ---- Zone bar in standings ---- */
.ff-standings-table td:first-child { position: relative; padding-left: 14px; }
.ff-zone-bar { position: absolute; left: 0; top: 0; bottom: 0; width: 3px; }
.ff-zone-bar--cl { background: var(--ff-zone-cl); }
.ff-zone-bar--el { background: var(--ff-zone-el); }
.ff-zone-bar--cfl { background: var(--ff-zone-cfl); }
.ff-zone-bar--rel { background: var(--ff-zone-rel); }

/* Current team/entity highlight */
.ff-table__row--current { background: rgba(59,130,246,.08); }

/* Zone legend */
.ff-standings-legend {
  padding: 8px 12px; border-top: 1px solid var(--ff-color-border);
  display: flex; flex-wrap: wrap; gap: 14px;
}
.ff-standings-legend__item { display: inline-flex; align-items: center; gap: 5px; font-size: 11px; color: var(--ff-color-muted); }
.ff-standings-legend__dot { width: 8px; height: 8px; border-radius: 50%; flex: 0 0 auto; }

/* ---- Percentile stats (player) ---- */
.ff-stat-pct__section { padding: 14px 16px 10px; }
.ff-stat-pct__section + .ff-stat-pct__section { border-top: 1px solid var(--ff-color-border); }
.ff-stat-pct__category { margin: 0 0 4px; font: 800 12px/1 var(--ff-font-display); color: var(--ff-color-muted); text-transform: uppercase; letter-spacing: 0.05em; }
.ff-stat-pct__tip { margin: 0 0 12px; color: rgba(148,163,184,.5); font-size: 11px; }
.ff-stat-pct__row {
  display: grid; grid-template-columns: 1fr 58px 1fr 90px;
  align-items: center; gap: 10px;
  padding: 7px 0; border-bottom: 1px solid rgba(255,255,255,.04);
}
.ff-stat-pct__row:last-child { border-bottom: 0; }
.ff-stat-pct__name { font-size: 12px; }
.ff-stat-pct__val { font: 700 13px/1 var(--ff-font-mono); color: var(--ff-color-primary-text); text-align: right; }
.ff-stat-pct__bar-wrap { height: 5px; border-radius: var(--ff-radius-pill); background: rgba(255,255,255,.08); overflow: hidden; }
.ff-stat-pct__bar { height: 100%; border-radius: var(--ff-radius-pill); background: linear-gradient(90deg, rgba(59,130,246,.4) 0%, var(--ff-color-primary) 100%); }
.ff-stat-pct__rank { color: var(--ff-color-muted); font: 500 11px/1 var(--ff-font-mono); text-align: right; white-space: nowrap; }

/* ---- Squad table (team hub) ---- */
.ff-squad-pos-header {
  display: flex; align-items: center; gap: 8px;
  padding: 8px 12px;
  background: rgba(255,255,255,.02);
  border-top: 1px solid var(--ff-color-border);
}
.ff-squad-pos-header:first-child { border-top: 0; }
.ff-squad-pos-label {
  padding: 2px 7px; border-radius: var(--ff-radius);
  background: var(--ff-color-primary-soft); color: var(--ff-color-primary-text);
  font: 800 11px/1.4 var(--ff-font-display);
}
.ff-squad-pos-count { color: var(--ff-color-muted); font: 500 12px/1 var(--ff-font-mono); }
.ff-squad-table {
  width: 100%; border-collapse: collapse; min-width: 460px;
  font: 500 12px/1.4 var(--ff-font-body);
}
.ff-squad-table th {
  padding: 7px 10px; background: rgba(255,255,255,.02);
  color: var(--ff-color-muted); text-align: left; font: 700 11px/1 var(--ff-font-mono);
}
.ff-squad-table td { padding: 8px 10px; border-top: 1px solid rgba(255,255,255,.05); }
.ff-squad-table__num { color: var(--ff-color-muted); font-family: var(--ff-font-mono); font-size: 12px; width: 30px; }
.ff-squad-table__name a { font-weight: 700; }
.ff-squad-table__name a:hover { color: var(--ff-color-primary-text); }
.ff-squad-table__pos span { display: inline-block; padding: 1px 5px; border-radius: 3px; background: rgba(255,255,255,.06); font: 700 10px/1.5 var(--ff-font-mono); }
.ff-squad-table__nat { color: var(--ff-color-muted); font-size: 12px; }
.ff-squad-table__age { color: var(--ff-color-muted); font-family: var(--ff-font-mono); font-size: 12px; text-align: right; }
.ff-squad-table__goals { color: var(--ff-color-primary-text); font: 700 13px/1 var(--ff-font-mono); text-align: right; }

/* ---- Career stats (player hub) ---- */
.ff-career-table { width: 100%; min-width: 540px; border-collapse: collapse; font: 500 12px/1.4 var(--ff-font-mono); }
.ff-career-table th { padding: 9px 8px; background: rgba(255,255,255,.035); color: var(--ff-color-muted); text-align: left; font-weight: 700; }
.ff-career-table td { padding: 9px 8px; border-top: 1px solid rgba(255,255,255,.06); }
.ff-career-table__club { font-family: var(--ff-font-body); font-weight: 700; }
.ff-career-table__goals { color: var(--ff-color-primary-text); font-weight: 800; }
.ff-career-table__current { background: rgba(59,130,246,.06); }

/* ---- League averages panel (league hub) ---- */
.ff-league-avg-grid { display: grid; grid-template-columns: repeat(3,minmax(0,1fr)); gap: 10px; padding: 14px; }
.ff-league-avg-item {
  padding: 12px; border: 1px solid var(--ff-color-border); border-radius: var(--ff-radius);
  background: rgba(15,23,42,.55); display: flex; flex-direction: column; gap: 4px;
}
.ff-league-avg-item strong { font: 800 20px/1 var(--ff-font-display); color: var(--ff-color-primary-text); }
.ff-league-avg-item span { color: var(--ff-color-muted); font: 500 11px/1 var(--ff-font-mono); }
.ff-league-avg-item small { color: rgba(148,163,184,.4); font-size: 10px; }

/* ---- Club comparison table (league hub) ---- */
.ff-club-table { width: 100%; min-width: 540px; border-collapse: collapse; font: 500 12px/1.4 var(--ff-font-mono); }
.ff-club-table th { padding: 9px 8px; background: rgba(255,255,255,.035); color: var(--ff-color-muted); text-align: left; font-weight: 700; }
.ff-club-table td { padding: 9px 8px; border-top: 1px solid rgba(255,255,255,.06); }
.ff-club-table__name { font-family: var(--ff-font-body); font-weight: 700; }
.ff-club-table__name a { color: inherit; }
.ff-club-table__name a:hover { color: var(--ff-color-primary-text); }
.ff-club-table__pts { color: var(--ff-color-primary-text); font-weight: 800; }

/* ---- Home hub nav ---- */
.ff-hub-nav-cards {
  display: grid; grid-template-columns: repeat(3, minmax(0,1fr)); gap: 12px;
}
.ff-hub-nav-card {
  min-height: 96px; padding: 16px;
  border: 1px solid var(--ff-color-border); border-radius: var(--ff-radius);
  background: var(--ff-color-card); display: flex; flex-direction: column;
  gap: 6px; transition: border-color .14s, background .14s;
}
.ff-hub-nav-card:hover {
  border-color: rgba(59,130,246,.5); background: rgba(59,130,246,.05);
}
.ff-hub-nav-card__label {
  color: var(--ff-color-primary-text);
  font: 700 10px/1 var(--ff-font-mono);
  text-transform: uppercase; letter-spacing: 0.05em;
}
.ff-hub-nav-card__title { font: 800 15px/1.2 var(--ff-font-display); }
.ff-hub-nav-card__sub { color: var(--ff-color-muted); font-size: 11px; }

/* ---- Responsive ---- */
@media (max-width: 767px) {
  .ff-hub-nav-cards { grid-template-columns: 1fr 1fr; }

  .ff-hub-hero__strip { grid-template-columns: repeat(2, minmax(0,1fr)); }
  .ff-hub-hero__strip-item:nth-child(2) { border-right: 0; }
  .ff-hub-hero__strip-item:nth-child(3) { border-top: 1px solid var(--ff-color-border); }
  .ff-hub-hero__strip-item:nth-child(4) { border-top: 1px solid var(--ff-color-border); }

  .ff-player-hero-v2__cols { grid-template-columns: 1fr; }
  .ff-player-hero-v2__col + .ff-player-hero-v2__col { border-left: 0; border-top: 1px solid var(--ff-color-border); }

  .ff-stat-pct__row { grid-template-columns: 1fr 52px 82px; }
  .ff-stat-pct__bar-wrap { display: none; }

  .ff-league-avg-grid { grid-template-columns: repeat(2, minmax(0,1fr)); }

  /* Sticky first 2 cols on mobile for standings */
  .ff-standings-table--sticky .ff-table-wrap { position: relative; }
  .ff-standings-table--sticky thead th:first-child,
  .ff-standings-table--sticky tbody td:first-child {
    position: sticky; left: 0; z-index: 2;
    background: var(--ff-color-card); min-width: 34px;
  }
  .ff-standings-table--sticky thead th:nth-child(2),
  .ff-standings-table--sticky tbody td:nth-child(2) {
    position: sticky; left: 34px; z-index: 2;
    background: var(--ff-color-card); min-width: 100px;
    box-shadow: 2px 0 5px rgba(0,0,0,.3);
  }
  .ff-standings-table--sticky tr.ff-table__row--current td:first-child,
  .ff-standings-table--sticky tr.ff-table__row--current td:nth-child(2) {
    background: color-mix(in srgb, var(--ff-color-card) 70%, #3B82F6 30%);
  }
}
